@ndla/ui 52.0.0 → 53.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 (59) hide show
  1. package/es/Article/Article.js +110 -117
  2. package/es/Article/ArticleHeaderWrapper.js +14 -9
  3. package/es/all.css +1 -1
  4. package/es/index.js +0 -1
  5. package/es/locale/messages-en.js +3 -0
  6. package/es/locale/messages-nb.js +3 -0
  7. package/es/locale/messages-nn.js +3 -0
  8. package/es/locale/messages-se.js +3 -0
  9. package/es/locale/messages-sma.js +3 -0
  10. package/lib/Article/Article.d.ts +4 -5
  11. package/lib/Article/Article.js +108 -115
  12. package/lib/Article/ArticleHeaderWrapper.js +14 -9
  13. package/lib/Article/index.d.ts +1 -0
  14. package/lib/all.css +1 -1
  15. package/lib/index.d.ts +1 -1
  16. package/lib/index.js +0 -25
  17. package/lib/locale/messages-en.d.ts +3 -0
  18. package/lib/locale/messages-en.js +3 -0
  19. package/lib/locale/messages-nb.d.ts +3 -0
  20. package/lib/locale/messages-nb.js +3 -0
  21. package/lib/locale/messages-nn.d.ts +3 -0
  22. package/lib/locale/messages-nn.js +3 -0
  23. package/lib/locale/messages-se.d.ts +3 -0
  24. package/lib/locale/messages-se.js +3 -0
  25. package/lib/locale/messages-sma.d.ts +3 -0
  26. package/lib/locale/messages-sma.js +3 -0
  27. package/package.json +2 -3
  28. package/src/Article/Article.tsx +177 -113
  29. package/src/Article/ArticleHeaderWrapper.tsx +16 -9
  30. package/src/Article/index.ts +2 -0
  31. package/src/all.scss +2 -3
  32. package/src/index.ts +2 -2
  33. package/src/locale/messages-en.ts +3 -0
  34. package/src/locale/messages-nb.ts +3 -0
  35. package/src/locale/messages-nn.ts +3 -0
  36. package/src/locale/messages-se.ts +3 -0
  37. package/src/locale/messages-sma.ts +3 -0
  38. package/es/Article/ArticleNotions.js +0 -90
  39. package/es/Masthead/Masthead.js +0 -62
  40. package/es/Masthead/SkipToMainContent.js +0 -30
  41. package/es/Masthead/index.js +0 -13
  42. package/es/Masthead/utils.js +0 -38
  43. package/lib/Article/ArticleNotions.d.ts +0 -14
  44. package/lib/Article/ArticleNotions.js +0 -96
  45. package/lib/Masthead/Masthead.d.ts +0 -23
  46. package/lib/Masthead/Masthead.js +0 -68
  47. package/lib/Masthead/SkipToMainContent.d.ts +0 -12
  48. package/lib/Masthead/SkipToMainContent.js +0 -37
  49. package/lib/Masthead/index.d.ts +0 -12
  50. package/lib/Masthead/index.js +0 -36
  51. package/lib/Masthead/utils.d.ts +0 -11
  52. package/lib/Masthead/utils.js +0 -46
  53. package/src/Article/ArticleNotions.tsx +0 -139
  54. package/src/Article/component.article.scss +0 -149
  55. package/src/Masthead/Masthead.tsx +0 -100
  56. package/src/Masthead/SkipToMainContent.tsx +0 -54
  57. package/src/Masthead/index.ts +0 -16
  58. package/src/Masthead/utils.ts +0 -45
  59. package/src/main.scss +0 -4
@@ -8,36 +8,76 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
8
8
  *
9
9
  */
10
10
 
11
- import { useEffect, useRef, useState, forwardRef } from "react";
12
- import BEMHelper from "react-bem-helper";
13
- import { spacing, mq, breakpoints } from "@ndla/core";
14
- import { useIntersectionObserver } from "@ndla/hooks";
11
+ import { forwardRef, useMemo } from "react";
12
+ import { css } from "@emotion/react";
13
+ import { spacing, mq, breakpoints, fonts, colors, spacingUnit } from "@ndla/core";
15
14
  import { Heading, Text } from "@ndla/typography";
16
- import { resizeObserver } from "@ndla/util";
17
15
  import ArticleByline from "./ArticleByline";
18
16
  import ArticleHeaderWrapper from "./ArticleHeaderWrapper";
19
- import ArticleNotions from "./ArticleNotions";
20
17
  import LayoutItem from "../Layout";
21
18
  import MessageBox from "../Messages/MessageBox";
22
19
  import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
23
- const classes = new BEMHelper({
24
- name: "article",
25
- prefix: "c-"
26
- });
20
+ const StyledArticle = /*#__PURE__*/_styled("article", {
21
+ target: "ekgxh1z4",
22
+ label: "StyledArticle"
23
+ })("font-family:", fonts.serif, ";background:", colors.white, ";margin-top:", spacing.large, ";margin-right:auto;margin-bottom:", spacing.normal, ";margin-left:auto;overflow-wrap:break-word;", fonts.sizes("18px", "29px"), ";position:relative;mjx-stretchy-v>mjx-ext>mjx-c{transform:scaleY(100) translateY(0.075em);}>section>p{&:not([class]){margin-bottom:29px;}}", mq.range({
24
+ from: breakpoints.tablet
25
+ }), "{", fonts.sizes("18px", "29px"), ";padding:0 ", spacing.normal, " ", spacing.normal, ";margin-bottom:", spacing.large, ";margin-top:-", spacingUnit * 6, "px;padding-top:", spacing.xlarge, ";>section>p{&:not([class]){margin-bottom:35px;}}}", mq.range({
26
+ from: breakpoints.desktop
27
+ }), "{padding-bottom:", spacing.large, ";margin-bottom:", spacing.large, ";}&::after{content:\"\";display:table;clear:both;}p{margin-top:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAiCoC","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"));
28
+
29
+ // Make sure to wrap modifiers in & {} to avoid specificity issues
30
+ const articleModifiers = {
31
+ clean: /*#__PURE__*/css("&{margin-top:", spacing.normal, "!important;padding:", spacing.small, "!important;border:none;", mq.range({
32
+ from: breakpoints.tablet
33
+ }), "{padding:0!important;}};label:clean;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAqFY","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */")),
34
+ "in-topic": /*#__PURE__*/css("&{margin-top:0!important;padding:0!important;padding-left:", spacing.medium, "!important;};label:in-topic;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AA+FiB","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"))
35
+ };
36
+ const borderCss = /*#__PURE__*/css(mq.range({
37
+ from: breakpoints.tablet
38
+ }), "{border:2px solid var(--color);};label:borderCss;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAwGqB","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"));
27
39
  export const ArticleWrapper = /*#__PURE__*/forwardRef((_ref, ref) => {
28
40
  let {
29
41
  children,
30
42
  modifier,
31
- className,
32
43
  ...rest
33
44
  } = _ref;
34
- return _jsx("article", {
45
+ const borderColor = useMemo(() => {
46
+ let color = undefined;
47
+ if (modifier === "subject-material") {
48
+ color = colors.subjectMaterial.light;
49
+ } else if (modifier === "assessment-resources") {
50
+ color = colors.assessmentResource.background;
51
+ } else if (modifier === "tasks-and-activities") {
52
+ color = colors.tasksAndActivities.background;
53
+ } else if (modifier === "concept") {
54
+ color = colors.concept.light;
55
+ } else if (modifier === "source-material") {
56
+ color = colors.sourceMaterial.light;
57
+ }
58
+ if (color) {
59
+ return {
60
+ "--color": color
61
+ };
62
+ }
63
+ return undefined;
64
+ }, [modifier]);
65
+ return _jsx(StyledArticle, {
66
+ css: [borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined, ";label:ArticleWrapper;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAoIM","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */")],
67
+ style: borderColor,
35
68
  ...rest,
36
- ...classes(undefined, modifier, className),
37
69
  ref: ref,
38
70
  children: children
39
71
  });
40
72
  });
73
+ const TitleLabelText = /*#__PURE__*/_styled(Text, {
74
+ target: "ekgxh1z3",
75
+ label: "TitleLabelText"
76
+ })("color:#757575;text-transform:uppercase;font-family:", fonts.sans, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAsJmC","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"));
77
+ const ArticleTitleWrapper = /*#__PURE__*/_styled("div", {
78
+ target: "ekgxh1z2",
79
+ label: "ArticleTitleWrapper"
80
+ })("display:flex;gap:", spacing.normal, ";align-items:flex-start;h1{overflow-wrap:anywhere;}padding-bottom:", spacing.medium, ";[data-badge]{flex-shrink:0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AA4JsC","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"));
41
81
  export const ArticleTitle = _ref2 => {
42
82
  let {
43
83
  children,
@@ -46,25 +86,21 @@ export const ArticleTitle = _ref2 => {
46
86
  id,
47
87
  lang
48
88
  } = _ref2;
49
- const modifiers = [];
50
- if (icon) {
51
- modifiers.push("icon");
52
- }
53
- let labelView = null;
54
- if (label) {
55
- labelView = _jsx("p", {
56
- children: label
57
- });
58
- }
59
- return _jsxs("div", {
60
- ...classes("title", modifiers),
61
- children: [icon, labelView, _jsx(Heading, {
62
- element: "h1",
63
- headingStyle: "h1-resource",
64
- id: id,
65
- tabIndex: -1,
66
- lang: lang,
67
- children: children
89
+ return _jsxs(ArticleTitleWrapper, {
90
+ children: [icon, _jsxs("hgroup", {
91
+ children: [!!label && _jsx(TitleLabelText, {
92
+ textStyle: "meta-text-medium",
93
+ margin: "none",
94
+ children: label
95
+ }), _jsx(Heading, {
96
+ element: "h1",
97
+ margin: "none",
98
+ headingStyle: "h1-resource",
99
+ id: id,
100
+ tabIndex: -1,
101
+ lang: lang,
102
+ children: children
103
+ })]
68
104
  })]
69
105
  });
70
106
  };
@@ -92,7 +128,7 @@ const MSGboxWrapper = /*#__PURE__*/_styled("div", {
92
128
  } : {
93
129
  name: "15u9bv0",
94
130
  styles: "margin-bottom:50px",
95
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AA2FgC","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 { ReactNode, useEffect, useRef, useState, forwardRef, ComponentPropsWithRef } from \"react\";\nimport BEMHelper from \"react-bem-helper\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints } from \"@ndla/core\";\nimport { useIntersectionObserver } from \"@ndla/hooks\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport { resizeObserver } from \"@ndla/util\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport ArticleNotions from \"./ArticleNotions\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nconst classes = new BEMHelper({\n  name: \"article\",\n  prefix: \"c-\",\n});\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: string;\n}\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(\n  ({ children, modifier, className, ...rest }, ref) => (\n    <article {...rest} {...classes(undefined, modifier, className)} ref={ref}>\n      {children}\n    </article>\n  ),\n);\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: 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      <Heading element=\"h1\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${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  contentTransformed?: boolean;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  notions?: ReactNode;\n  lang?: string;\n};\n\nconst getArticleContent = (content: any, contentTransformed?: boolean) => {\n  if (contentTransformed) {\n    return content;\n  }\n  switch (typeof content) {\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  id,\n  notions,\n  heartButton,\n  contentTransformed,\n  lang,\n}: Props) => {\n  const articleRef = useRef<HTMLDivElement>(null);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const { entry } = useIntersectionObserver({\n    rootMargin: \"400px\",\n    target: articleRef.current,\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n\n  const showExplainNotions = !!entry?.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef?.current) {\n      const handler = () => {\n        if (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 { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} ref={articleRef} data-ndla-article=\"\">\n        <LayoutItem layout=\"center\">\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n            <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions buttonOffsetRight={articlePositionRight}>{notions}</ArticleNotions>\n          )}\n          {getArticleContent(content, contentTransformed)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          <ArticleByline\n            footnotes={footNotes}\n            authors={authors}\n            suppliers={copyright?.rightsholders}\n            published={published}\n            license={copyright?.license?.license ?? \"\"}\n            licenseBox={licenseBox}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */",
131
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AA6MgC","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */",
96
132
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
97
133
  });
98
134
  const ArticleFavoritesButtonWrapper = /*#__PURE__*/_styled("div", {
@@ -100,18 +136,7 @@ const ArticleFavoritesButtonWrapper = /*#__PURE__*/_styled("div", {
100
136
  label: "ArticleFavoritesButtonWrapper"
101
137
  })("display:flex;justify-content:flex-end;transform:translate(", spacing.xsmall, ", -", spacing.normal, ");", mq.range({
102
138
  from: breakpoints.tablet
103
- }), "{transform:translate(", spacing.normal, ", -", spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AA+FgD","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 { ReactNode, useEffect, useRef, useState, forwardRef, ComponentPropsWithRef } from \"react\";\nimport BEMHelper from \"react-bem-helper\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints } from \"@ndla/core\";\nimport { useIntersectionObserver } from \"@ndla/hooks\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport { resizeObserver } from \"@ndla/util\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport ArticleNotions from \"./ArticleNotions\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nconst classes = new BEMHelper({\n  name: \"article\",\n  prefix: \"c-\",\n});\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: string;\n}\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(\n  ({ children, modifier, className, ...rest }, ref) => (\n    <article {...rest} {...classes(undefined, modifier, className)} ref={ref}>\n      {children}\n    </article>\n  ),\n);\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: 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      <Heading element=\"h1\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </div>\n  );\n};\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${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  contentTransformed?: boolean;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  notions?: ReactNode;\n  lang?: string;\n};\n\nconst getArticleContent = (content: any, contentTransformed?: boolean) => {\n  if (contentTransformed) {\n    return content;\n  }\n  switch (typeof content) {\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  id,\n  notions,\n  heartButton,\n  contentTransformed,\n  lang,\n}: Props) => {\n  const articleRef = useRef<HTMLDivElement>(null);\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const { entry } = useIntersectionObserver({\n    rootMargin: \"400px\",\n    target: articleRef.current,\n    threshold: 0.1,\n  });\n  const [articlePositionRight, setArticlePositionRight] = useState(0);\n\n  const showExplainNotions = !!entry?.isIntersecting;\n\n  useEffect(() => {\n    if (wrapperRef?.current) {\n      const handler = () => {\n        if (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 { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <div ref={wrapperRef}>\n      <ArticleWrapper modifier={modifier} ref={articleRef} data-ndla-article=\"\">\n        <LayoutItem layout=\"center\">\n          {messages.messageBox && (\n            <MSGboxWrapper>\n              <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n            </MSGboxWrapper>\n          )}\n          <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n            {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n            <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n              {title}\n            </ArticleTitle>\n            <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n          </ArticleHeaderWrapper>\n        </LayoutItem>\n        <LayoutItem layout=\"center\">\n          {notions && showExplainNotions && (\n            <ArticleNotions buttonOffsetRight={articlePositionRight}>{notions}</ArticleNotions>\n          )}\n          {getArticleContent(content, contentTransformed)}\n        </LayoutItem>\n\n        <LayoutItem layout=\"center\">\n          <ArticleByline\n            footnotes={footNotes}\n            authors={authors}\n            suppliers={copyright?.rightsholders}\n            published={published}\n            license={copyright?.license?.license ?? \"\"}\n            licenseBox={licenseBox}\n          />\n        </LayoutItem>\n        <LayoutItem layout=\"extend\">{children}</LayoutItem>\n      </ArticleWrapper>\n    </div>\n  );\n};\n\nexport default Article;\n"]} */"));
104
- const getArticleContent = (content, contentTransformed) => {
105
- if (contentTransformed) {
106
- return content;
107
- }
108
- switch (typeof content) {
109
- case "function":
110
- return content();
111
- default:
112
- return content;
113
- }
114
- };
139
+ }), "{transform:translate(", spacing.normal, ", -", spacing.medium, ");}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Article.tsx"],"names":[],"mappings":"AAiNgD","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 { ReactNode, forwardRef, ComponentPropsWithRef, useMemo, CSSProperties } from \"react\";\nimport { SerializedStyles, css } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\n\nimport { spacing, mq, breakpoints, fonts, colors, spacingUnit } from \"@ndla/core\";\nimport { Heading, Text } from \"@ndla/typography\";\nimport ArticleByline from \"./ArticleByline\";\nimport ArticleHeaderWrapper from \"./ArticleHeaderWrapper\";\nimport LayoutItem from \"../Layout\";\nimport MessageBox from \"../Messages/MessageBox\";\nimport { Article as ArticleType } from \"../types\";\n\nexport type ArticleModifier =\n  | \"clean\"\n  | \"in-topic\"\n  | \"subject-material\"\n  | \"assessment-resources\"\n  | \"tasks-and-activities\"\n  | \"concept\"\n  | \"source-material\";\n\ninterface ArticleWrapperProps extends ComponentPropsWithRef<\"article\"> {\n  modifier?: ArticleModifier;\n}\n\nconst StyledArticle = styled.article`\n  font-family: ${fonts.serif};\n  background: ${colors.white};\n  margin-top: ${spacing.large};\n  margin-right: auto;\n  margin-bottom: ${spacing.normal};\n  margin-left: auto;\n  overflow-wrap: break-word;\n  ${fonts.sizes(\"18px\", \"29px\")};\n  position: relative;\n\n  mjx-stretchy-v > mjx-ext > mjx-c {\n    transform: scaleY(100) translateY(0.075em);\n  }\n\n  > section > p {\n    &:not([class]) {\n      margin-bottom: 29px;\n    }\n  }\n\n  ${mq.range({ from: breakpoints.tablet })} {\n    ${fonts.sizes(\"18px\", \"29px\")}; //This is probably not needed, but it's here to be sure.\n\n    > section > p {\n      &:not([class]) {\n        margin-bottom: 35px;\n      }\n    }\n    padding: 0 ${spacing.normal} ${spacing.normal};\n    margin-bottom: ${spacing.large};\n    margin-top: -${spacingUnit * 6}px;\n    padding-top: ${spacing.xlarge};\n  }\n  ${mq.range({ from: breakpoints.desktop })} {\n    padding-bottom: ${spacing.large};\n    margin-bottom: ${spacing.large};\n  }\n\n  &::after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n\n  p {\n    margin-top: 0;\n  }\n`;\n\n// Make sure to wrap modifiers in & {} to avoid specificity issues\nconst articleModifiers: Partial<Record<ArticleModifier, SerializedStyles>> = {\n  clean: css`\n    & {\n      margin-top: ${spacing.normal} !important;\n      padding: ${spacing.small} !important;\n      ${mq.range({ from: breakpoints.tablet })} {\n        padding: 0 !important;\n      }\n      border: none;\n    }\n  `,\n  \"in-topic\": css`\n    & {\n      margin-top: 0 !important;\n      padding: 0 !important;\n      padding-left: ${spacing.medium} !important;\n    }\n  `,\n};\n\nconst borderCss = css`\n  ${mq.range({ from: breakpoints.tablet })} {\n    border: 2px solid var(--color);\n  }\n`;\n\nexport const ArticleWrapper = forwardRef<HTMLElement, ArticleWrapperProps>(({ children, modifier, ...rest }, ref) => {\n  const borderColor = useMemo(() => {\n    let color = undefined;\n    if (modifier === \"subject-material\") {\n      color = colors.subjectMaterial.light;\n    } else if (modifier === \"assessment-resources\") {\n      color = colors.assessmentResource.background;\n    } else if (modifier === \"tasks-and-activities\") {\n      color = colors.tasksAndActivities.background;\n    } else if (modifier === \"concept\") {\n      color = colors.concept.light;\n    } else if (modifier === \"source-material\") {\n      color = colors.sourceMaterial.light;\n    }\n    if (color) {\n      return { \"--color\": color } as CSSProperties;\n    }\n    return undefined;\n  }, [modifier]);\n\n  return (\n    <StyledArticle\n      css={[borderColor ? borderCss : undefined, modifier ? articleModifiers[modifier] : undefined]}\n      style={borderColor}\n      {...rest}\n      ref={ref}\n    >\n      {children}\n    </StyledArticle>\n  );\n});\n\ntype ArticleTitleProps = {\n  icon?: ReactNode;\n  label?: string;\n  children: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nconst TitleLabelText = styled(Text)`\n  color: #757575;\n  text-transform: uppercase;\n  font-family: ${fonts.sans};\n`;\n\nconst ArticleTitleWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.normal};\n  align-items: flex-start;\n  h1 {\n    overflow-wrap: anywhere;\n  }\n  padding-bottom: ${spacing.medium};\n  [data-badge] {\n    flex-shrink: 0;\n  }\n`;\n\nexport const ArticleTitle = ({ children, icon, label, id, lang }: ArticleTitleProps) => (\n  <ArticleTitleWrapper>\n    {icon}\n    <hgroup>\n      {!!label && (\n        <TitleLabelText textStyle=\"meta-text-medium\" margin=\"none\">\n          {label}\n        </TitleLabelText>\n      )}\n      <Heading element=\"h1\" margin=\"none\" headingStyle=\"h1-resource\" id={id} tabIndex={-1} lang={lang}>\n        {children}\n      </Heading>\n    </hgroup>\n  </ArticleTitleWrapper>\n);\n\ntype ArticleIntroductionProps = {\n  children: ReactNode;\n  lang?: string;\n};\n\nexport const ArticleIntroduction = ({ children, lang }: ArticleIntroductionProps) => {\n  if (children) {\n    return (\n      <Text textStyle=\"ingress\" element=\"div\" lang={lang}>\n        {children}\n      </Text>\n    );\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  ${mq.range({ from: breakpoints.tablet })} {\n    transform: translate(${spacing.normal}, -${spacing.medium});\n  }\n`;\n\ntype Props = {\n  heartButton?: ReactNode;\n  article: ArticleType;\n  icon?: ReactNode;\n  licenseBox?: ReactNode;\n  modifier?: ArticleModifier;\n  children?: ReactNode;\n  messages: Messages;\n  messageBoxLinks?: [];\n  competenceGoals?: ReactNode;\n  id: string;\n  lang?: string;\n};\n\nexport const Article = ({\n  article,\n  icon,\n  licenseBox,\n  modifier,\n  messages,\n  messageBoxLinks,\n  children,\n  competenceGoals,\n  id,\n  heartButton,\n  lang,\n}: Props) => {\n  const { title, introduction, published, content, footNotes, copyright } = article;\n\n  const authors =\n    copyright?.creators.length || copyright?.rightsholders.length ? copyright.creators : copyright?.processors;\n\n  return (\n    <ArticleWrapper modifier={modifier} data-ndla-article=\"\">\n      <LayoutItem layout=\"center\">\n        {messages.messageBox && (\n          <MSGboxWrapper>\n            <MessageBox links={messageBoxLinks}>{messages.messageBox}</MessageBox>\n          </MSGboxWrapper>\n        )}\n        <ArticleHeaderWrapper competenceGoals={competenceGoals}>\n          {heartButton ? <ArticleFavoritesButtonWrapper>{heartButton}</ArticleFavoritesButtonWrapper> : null}\n          <ArticleTitle id={id} icon={icon} label={messages.label} lang={lang}>\n            {title}\n          </ArticleTitle>\n          <ArticleIntroduction lang={lang}>{introduction}</ArticleIntroduction>\n        </ArticleHeaderWrapper>\n      </LayoutItem>\n      <LayoutItem layout=\"center\">{content}</LayoutItem>\n      <LayoutItem layout=\"center\">\n        <ArticleByline\n          footnotes={footNotes}\n          authors={authors}\n          suppliers={copyright?.rightsholders}\n          published={published}\n          license={copyright?.license?.license ?? \"\"}\n          licenseBox={licenseBox}\n        />\n      </LayoutItem>\n      <LayoutItem layout=\"extend\">{children}</LayoutItem>\n    </ArticleWrapper>\n  );\n};\n\nexport default Article;\n"]} */"));
115
140
  export const Article = _ref4 => {
116
141
  var _copyright$license$li, _copyright$license;
117
142
  let {
@@ -124,34 +149,9 @@ export const Article = _ref4 => {
124
149
  children,
125
150
  competenceGoals,
126
151
  id,
127
- notions,
128
152
  heartButton,
129
- contentTransformed,
130
153
  lang
131
154
  } = _ref4;
132
- const articleRef = useRef(null);
133
- const wrapperRef = useRef(null);
134
- const {
135
- entry
136
- } = useIntersectionObserver({
137
- rootMargin: "400px",
138
- target: articleRef.current,
139
- threshold: 0.1
140
- });
141
- const [articlePositionRight, setArticlePositionRight] = useState(0);
142
- const showExplainNotions = !!(entry !== null && entry !== void 0 && entry.isIntersecting);
143
- useEffect(() => {
144
- if (wrapperRef !== null && wrapperRef !== void 0 && wrapperRef.current) {
145
- const handler = () => {
146
- if (wrapperRef !== null && wrapperRef !== void 0 && wrapperRef.current) {
147
- const offset = wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;
148
- setArticlePositionRight(offset);
149
- }
150
- };
151
- handler();
152
- return resizeObserver(document.body, handler);
153
- }
154
- }, [wrapperRef]);
155
155
  const {
156
156
  title,
157
157
  introduction,
@@ -161,55 +161,48 @@ export const Article = _ref4 => {
161
161
  copyright
162
162
  } = article;
163
163
  const authors = copyright !== null && copyright !== void 0 && copyright.creators.length || copyright !== null && copyright !== void 0 && copyright.rightsholders.length ? copyright.creators : copyright === null || copyright === void 0 ? void 0 : copyright.processors;
164
- return _jsx("div", {
165
- ref: wrapperRef,
166
- children: _jsxs(ArticleWrapper, {
167
- modifier: modifier,
168
- ref: articleRef,
169
- "data-ndla-article": "",
170
- children: [_jsxs(LayoutItem, {
171
- layout: "center",
172
- children: [messages.messageBox && _jsx(MSGboxWrapper, {
173
- children: _jsx(MessageBox, {
174
- links: messageBoxLinks,
175
- children: messages.messageBox
176
- })
177
- }), _jsxs(ArticleHeaderWrapper, {
178
- competenceGoals: competenceGoals,
179
- children: [heartButton ? _jsx(ArticleFavoritesButtonWrapper, {
180
- children: heartButton
181
- }) : null, _jsx(ArticleTitle, {
182
- id: id,
183
- icon: icon,
184
- label: messages.label,
185
- lang: lang,
186
- children: title
187
- }), _jsx(ArticleIntroduction, {
188
- lang: lang,
189
- children: introduction
190
- })]
191
- })]
192
- }), _jsxs(LayoutItem, {
193
- layout: "center",
194
- children: [notions && showExplainNotions && _jsx(ArticleNotions, {
195
- buttonOffsetRight: articlePositionRight,
196
- children: notions
197
- }), getArticleContent(content, contentTransformed)]
198
- }), _jsx(LayoutItem, {
199
- layout: "center",
200
- children: _jsx(ArticleByline, {
201
- footnotes: footNotes,
202
- authors: authors,
203
- suppliers: copyright === null || copyright === void 0 ? void 0 : copyright.rightsholders,
204
- published: published,
205
- license: (_copyright$license$li = copyright === null || copyright === void 0 || (_copyright$license = copyright.license) === null || _copyright$license === void 0 ? void 0 : _copyright$license.license) !== null && _copyright$license$li !== void 0 ? _copyright$license$li : "",
206
- licenseBox: licenseBox
164
+ return _jsxs(ArticleWrapper, {
165
+ modifier: modifier,
166
+ "data-ndla-article": "",
167
+ children: [_jsxs(LayoutItem, {
168
+ layout: "center",
169
+ children: [messages.messageBox && _jsx(MSGboxWrapper, {
170
+ children: _jsx(MessageBox, {
171
+ links: messageBoxLinks,
172
+ children: messages.messageBox
207
173
  })
208
- }), _jsx(LayoutItem, {
209
- layout: "extend",
210
- children: children
174
+ }), _jsxs(ArticleHeaderWrapper, {
175
+ competenceGoals: competenceGoals,
176
+ children: [heartButton ? _jsx(ArticleFavoritesButtonWrapper, {
177
+ children: heartButton
178
+ }) : null, _jsx(ArticleTitle, {
179
+ id: id,
180
+ icon: icon,
181
+ label: messages.label,
182
+ lang: lang,
183
+ children: title
184
+ }), _jsx(ArticleIntroduction, {
185
+ lang: lang,
186
+ children: introduction
187
+ })]
211
188
  })]
212
- })
189
+ }), _jsx(LayoutItem, {
190
+ layout: "center",
191
+ children: content
192
+ }), _jsx(LayoutItem, {
193
+ layout: "center",
194
+ children: _jsx(ArticleByline, {
195
+ footnotes: footNotes,
196
+ authors: authors,
197
+ suppliers: copyright === null || copyright === void 0 ? void 0 : copyright.rightsholders,
198
+ published: published,
199
+ license: (_copyright$license$li = copyright === null || copyright === void 0 || (_copyright$license = copyright.license) === null || _copyright$license === void 0 ? void 0 : _copyright$license.license) !== null && _copyright$license$li !== void 0 ? _copyright$license$li : "",
200
+ licenseBox: licenseBox
201
+ })
202
+ }), _jsx(LayoutItem, {
203
+ layout: "extend",
204
+ children: children
205
+ })]
213
206
  });
214
207
  };
215
208
  export default Article;
@@ -1,3 +1,4 @@
1
+ import _styled from "@emotion/styled/base";
1
2
  /**
2
3
  * Copyright (c) 2016-present, NDLA.
3
4
  *
@@ -6,21 +7,25 @@
6
7
  *
7
8
  */
8
9
 
9
- import BEMHelper from "react-bem-helper";
10
+ import { breakpoints, mq, spacing } from "@ndla/core";
10
11
  import { jsx as _jsx, jsxs as _jsxs } from "@emotion/react/jsx-runtime";
11
- const classes = new BEMHelper({
12
- name: "article",
13
- prefix: "c-"
14
- });
12
+ const StyledHeaderWrapper = /*#__PURE__*/_styled("div", {
13
+ target: "e1daii1f1",
14
+ label: "StyledHeaderWrapper"
15
+ })("margin-bottom:", spacing.normal, ";", mq.range({
16
+ from: breakpoints.tablet
17
+ }), "{margin-bottom:", spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnNDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86IFJlYWN0Tm9kZTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZEhlYWRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi1ib3R0b206ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbmA7XG5cbmNvbnN0IENvbXBldGVuY2VXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBBcnRpY2xlSGVhZGVyV3JhcHBlciA9ICh7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMgfTogUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyV3JhcHBlcj5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj57Y29tcGV0ZW5jZUdvYWxzfTwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgPC9TdHlsZWRIZWFkZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQXJ0aWNsZUhlYWRlcldyYXBwZXI7XG4iXX0= */"));
18
+ const CompetenceWrapper = /*#__PURE__*/_styled("div", {
19
+ target: "e1daii1f0",
20
+ label: "CompetenceWrapper"
21
+ })("margin-top:", spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Qm9DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86IFJlYWN0Tm9kZTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZEhlYWRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi1ib3R0b206ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbmA7XG5cbmNvbnN0IENvbXBldGVuY2VXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBBcnRpY2xlSGVhZGVyV3JhcHBlciA9ICh7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMgfTogUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyV3JhcHBlcj5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj57Y29tcGV0ZW5jZUdvYWxzfTwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgPC9TdHlsZWRIZWFkZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQXJ0aWNsZUhlYWRlcldyYXBwZXI7XG4iXX0= */"));
15
22
  const ArticleHeaderWrapper = _ref => {
16
23
  let {
17
24
  children,
18
25
  competenceGoals
19
26
  } = _ref;
20
- return _jsxs("div", {
21
- ...classes("header"),
22
- children: [children, _jsx("div", {
23
- ...classes("competence"),
27
+ return _jsxs(StyledHeaderWrapper, {
28
+ children: [children, _jsx(CompetenceWrapper, {
24
29
  children: competenceGoals
25
30
  })]
26
31
  });