@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.
- package/es/Article/Article.js +110 -117
- package/es/Article/ArticleHeaderWrapper.js +14 -9
- package/es/all.css +1 -1
- package/es/index.js +0 -1
- package/es/locale/messages-en.js +3 -0
- package/es/locale/messages-nb.js +3 -0
- package/es/locale/messages-nn.js +3 -0
- package/es/locale/messages-se.js +3 -0
- package/es/locale/messages-sma.js +3 -0
- package/lib/Article/Article.d.ts +4 -5
- package/lib/Article/Article.js +108 -115
- package/lib/Article/ArticleHeaderWrapper.js +14 -9
- package/lib/Article/index.d.ts +1 -0
- package/lib/all.css +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.js +0 -25
- package/lib/locale/messages-en.d.ts +3 -0
- package/lib/locale/messages-en.js +3 -0
- package/lib/locale/messages-nb.d.ts +3 -0
- package/lib/locale/messages-nb.js +3 -0
- package/lib/locale/messages-nn.d.ts +3 -0
- package/lib/locale/messages-nn.js +3 -0
- package/lib/locale/messages-se.d.ts +3 -0
- package/lib/locale/messages-se.js +3 -0
- package/lib/locale/messages-sma.d.ts +3 -0
- package/lib/locale/messages-sma.js +3 -0
- package/package.json +2 -3
- package/src/Article/Article.tsx +177 -113
- package/src/Article/ArticleHeaderWrapper.tsx +16 -9
- package/src/Article/index.ts +2 -0
- package/src/all.scss +2 -3
- package/src/index.ts +2 -2
- package/src/locale/messages-en.ts +3 -0
- package/src/locale/messages-nb.ts +3 -0
- package/src/locale/messages-nn.ts +3 -0
- package/src/locale/messages-se.ts +3 -0
- package/src/locale/messages-sma.ts +3 -0
- package/es/Article/ArticleNotions.js +0 -90
- package/es/Masthead/Masthead.js +0 -62
- package/es/Masthead/SkipToMainContent.js +0 -30
- package/es/Masthead/index.js +0 -13
- package/es/Masthead/utils.js +0 -38
- package/lib/Article/ArticleNotions.d.ts +0 -14
- package/lib/Article/ArticleNotions.js +0 -96
- package/lib/Masthead/Masthead.d.ts +0 -23
- package/lib/Masthead/Masthead.js +0 -68
- package/lib/Masthead/SkipToMainContent.d.ts +0 -12
- package/lib/Masthead/SkipToMainContent.js +0 -37
- package/lib/Masthead/index.d.ts +0 -12
- package/lib/Masthead/index.js +0 -36
- package/lib/Masthead/utils.d.ts +0 -11
- package/lib/Masthead/utils.js +0 -46
- package/src/Article/ArticleNotions.tsx +0 -139
- package/src/Article/component.article.scss +0 -149
- package/src/Masthead/Masthead.tsx +0 -100
- package/src/Masthead/SkipToMainContent.tsx +0 -54
- package/src/Masthead/index.ts +0 -16
- package/src/Masthead/utils.ts +0 -45
- package/src/main.scss +0 -4
package/lib/Article/Article.js
CHANGED
|
@@ -6,14 +6,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = exports.ArticleWrapper = exports.ArticleTitle = exports.ArticleIntroduction = exports.Article = void 0;
|
|
7
7
|
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
8
|
var _react = require("react");
|
|
9
|
-
var
|
|
9
|
+
var _react2 = require("@emotion/react");
|
|
10
10
|
var _core = require("@ndla/core");
|
|
11
|
-
var _hooks = require("@ndla/hooks");
|
|
12
11
|
var _typography = require("@ndla/typography");
|
|
13
|
-
var _util = require("@ndla/util");
|
|
14
12
|
var _ArticleByline = _interopRequireDefault(require("./ArticleByline"));
|
|
15
13
|
var _ArticleHeaderWrapper = _interopRequireDefault(require("./ArticleHeaderWrapper"));
|
|
16
|
-
var _ArticleNotions = _interopRequireDefault(require("./ArticleNotions"));
|
|
17
14
|
var _Layout = _interopRequireDefault(require("../Layout"));
|
|
18
15
|
var _MessageBox = _interopRequireDefault(require("../Messages/MessageBox"));
|
|
19
16
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
@@ -25,24 +22,67 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringif
|
|
|
25
22
|
* LICENSE file in the root directory of this source tree.
|
|
26
23
|
*
|
|
27
24
|
*/
|
|
28
|
-
const
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
});
|
|
25
|
+
const StyledArticle = /*#__PURE__*/(0, _base.default)("article", {
|
|
26
|
+
target: "ekgxh1z4",
|
|
27
|
+
label: "StyledArticle"
|
|
28
|
+
})("font-family:", _core.fonts.serif, ";background:", _core.colors.white, ";margin-top:", _core.spacing.large, ";margin-right:auto;margin-bottom:", _core.spacing.normal, ";margin-left:auto;overflow-wrap:break-word;", _core.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;}}", _core.mq.range({
|
|
29
|
+
from: _core.breakpoints.tablet
|
|
30
|
+
}), "{", _core.fonts.sizes("18px", "29px"), ";padding:0 ", _core.spacing.normal, " ", _core.spacing.normal, ";margin-bottom:", _core.spacing.large, ";margin-top:-", _core.spacingUnit * 6, "px;padding-top:", _core.spacing.xlarge, ";>section>p{&:not([class]){margin-bottom:35px;}}}", _core.mq.range({
|
|
31
|
+
from: _core.breakpoints.desktop
|
|
32
|
+
}), "{padding-bottom:", _core.spacing.large, ";margin-bottom:", _core.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"]} */"));
|
|
33
|
+
|
|
34
|
+
// Make sure to wrap modifiers in & {} to avoid specificity issues
|
|
35
|
+
const articleModifiers = {
|
|
36
|
+
clean: /*#__PURE__*/(0, _react2.css)("&{margin-top:", _core.spacing.normal, "!important;padding:", _core.spacing.small, "!important;border:none;", _core.mq.range({
|
|
37
|
+
from: _core.breakpoints.tablet
|
|
38
|
+
}), "{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"]} */")),
|
|
39
|
+
"in-topic": /*#__PURE__*/(0, _react2.css)("&{margin-top:0!important;padding:0!important;padding-left:", _core.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"]} */"))
|
|
40
|
+
};
|
|
41
|
+
const borderCss = /*#__PURE__*/(0, _react2.css)(_core.mq.range({
|
|
42
|
+
from: _core.breakpoints.tablet
|
|
43
|
+
}), "{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"]} */"));
|
|
32
44
|
const ArticleWrapper = exports.ArticleWrapper = /*#__PURE__*/(0, _react.forwardRef)((_ref, ref) => {
|
|
33
45
|
let {
|
|
34
46
|
children,
|
|
35
47
|
modifier,
|
|
36
|
-
className,
|
|
37
48
|
...rest
|
|
38
49
|
} = _ref;
|
|
39
|
-
|
|
50
|
+
const borderColor = (0, _react.useMemo)(() => {
|
|
51
|
+
let color = undefined;
|
|
52
|
+
if (modifier === "subject-material") {
|
|
53
|
+
color = _core.colors.subjectMaterial.light;
|
|
54
|
+
} else if (modifier === "assessment-resources") {
|
|
55
|
+
color = _core.colors.assessmentResource.background;
|
|
56
|
+
} else if (modifier === "tasks-and-activities") {
|
|
57
|
+
color = _core.colors.tasksAndActivities.background;
|
|
58
|
+
} else if (modifier === "concept") {
|
|
59
|
+
color = _core.colors.concept.light;
|
|
60
|
+
} else if (modifier === "source-material") {
|
|
61
|
+
color = _core.colors.sourceMaterial.light;
|
|
62
|
+
}
|
|
63
|
+
if (color) {
|
|
64
|
+
return {
|
|
65
|
+
"--color": color
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
return undefined;
|
|
69
|
+
}, [modifier]);
|
|
70
|
+
return (0, _jsxRuntime.jsx)(StyledArticle, {
|
|
71
|
+
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"]} */")],
|
|
72
|
+
style: borderColor,
|
|
40
73
|
...rest,
|
|
41
|
-
...classes(undefined, modifier, className),
|
|
42
74
|
ref: ref,
|
|
43
75
|
children: children
|
|
44
76
|
});
|
|
45
77
|
});
|
|
78
|
+
const TitleLabelText = /*#__PURE__*/(0, _base.default)(_typography.Text, {
|
|
79
|
+
target: "ekgxh1z3",
|
|
80
|
+
label: "TitleLabelText"
|
|
81
|
+
})("color:#757575;text-transform:uppercase;font-family:", _core.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"]} */"));
|
|
82
|
+
const ArticleTitleWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
83
|
+
target: "ekgxh1z2",
|
|
84
|
+
label: "ArticleTitleWrapper"
|
|
85
|
+
})("display:flex;gap:", _core.spacing.normal, ";align-items:flex-start;h1{overflow-wrap:anywhere;}padding-bottom:", _core.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"]} */"));
|
|
46
86
|
const ArticleTitle = _ref2 => {
|
|
47
87
|
let {
|
|
48
88
|
children,
|
|
@@ -51,25 +91,21 @@ const ArticleTitle = _ref2 => {
|
|
|
51
91
|
id,
|
|
52
92
|
lang
|
|
53
93
|
} = _ref2;
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
id: id,
|
|
70
|
-
tabIndex: -1,
|
|
71
|
-
lang: lang,
|
|
72
|
-
children: children
|
|
94
|
+
return (0, _jsxRuntime.jsxs)(ArticleTitleWrapper, {
|
|
95
|
+
children: [icon, (0, _jsxRuntime.jsxs)("hgroup", {
|
|
96
|
+
children: [!!label && (0, _jsxRuntime.jsx)(TitleLabelText, {
|
|
97
|
+
textStyle: "meta-text-medium",
|
|
98
|
+
margin: "none",
|
|
99
|
+
children: label
|
|
100
|
+
}), (0, _jsxRuntime.jsx)(_typography.Heading, {
|
|
101
|
+
element: "h1",
|
|
102
|
+
margin: "none",
|
|
103
|
+
headingStyle: "h1-resource",
|
|
104
|
+
id: id,
|
|
105
|
+
tabIndex: -1,
|
|
106
|
+
lang: lang,
|
|
107
|
+
children: children
|
|
108
|
+
})]
|
|
73
109
|
})]
|
|
74
110
|
});
|
|
75
111
|
};
|
|
@@ -99,7 +135,7 @@ const MSGboxWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
99
135
|
} : {
|
|
100
136
|
name: "15u9bv0",
|
|
101
137
|
styles: "margin-bottom:50px",
|
|
102
|
-
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"]} */",
|
|
138
|
+
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"]} */",
|
|
103
139
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
104
140
|
});
|
|
105
141
|
const ArticleFavoritesButtonWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
@@ -107,18 +143,7 @@ const ArticleFavoritesButtonWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
107
143
|
label: "ArticleFavoritesButtonWrapper"
|
|
108
144
|
})("display:flex;justify-content:flex-end;transform:translate(", _core.spacing.xsmall, ", -", _core.spacing.normal, ");", _core.mq.range({
|
|
109
145
|
from: _core.breakpoints.tablet
|
|
110
|
-
}), "{transform:translate(", _core.spacing.normal, ", -", _core.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"]} */"));
|
|
111
|
-
const getArticleContent = (content, contentTransformed) => {
|
|
112
|
-
if (contentTransformed) {
|
|
113
|
-
return content;
|
|
114
|
-
}
|
|
115
|
-
switch (typeof content) {
|
|
116
|
-
case "function":
|
|
117
|
-
return content();
|
|
118
|
-
default:
|
|
119
|
-
return content;
|
|
120
|
-
}
|
|
121
|
-
};
|
|
146
|
+
}), "{transform:translate(", _core.spacing.normal, ", -", _core.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"]} */"));
|
|
122
147
|
const Article = _ref4 => {
|
|
123
148
|
var _copyright$license$li, _copyright$license;
|
|
124
149
|
let {
|
|
@@ -131,34 +156,9 @@ const Article = _ref4 => {
|
|
|
131
156
|
children,
|
|
132
157
|
competenceGoals,
|
|
133
158
|
id,
|
|
134
|
-
notions,
|
|
135
159
|
heartButton,
|
|
136
|
-
contentTransformed,
|
|
137
160
|
lang
|
|
138
161
|
} = _ref4;
|
|
139
|
-
const articleRef = (0, _react.useRef)(null);
|
|
140
|
-
const wrapperRef = (0, _react.useRef)(null);
|
|
141
|
-
const {
|
|
142
|
-
entry
|
|
143
|
-
} = (0, _hooks.useIntersectionObserver)({
|
|
144
|
-
rootMargin: "400px",
|
|
145
|
-
target: articleRef.current,
|
|
146
|
-
threshold: 0.1
|
|
147
|
-
});
|
|
148
|
-
const [articlePositionRight, setArticlePositionRight] = (0, _react.useState)(0);
|
|
149
|
-
const showExplainNotions = !!(entry !== null && entry !== void 0 && entry.isIntersecting);
|
|
150
|
-
(0, _react.useEffect)(() => {
|
|
151
|
-
if (wrapperRef !== null && wrapperRef !== void 0 && wrapperRef.current) {
|
|
152
|
-
const handler = () => {
|
|
153
|
-
if (wrapperRef !== null && wrapperRef !== void 0 && wrapperRef.current) {
|
|
154
|
-
const offset = wrapperRef.current.getBoundingClientRect().left + wrapperRef.current.getBoundingClientRect().width;
|
|
155
|
-
setArticlePositionRight(offset);
|
|
156
|
-
}
|
|
157
|
-
};
|
|
158
|
-
handler();
|
|
159
|
-
return (0, _util.resizeObserver)(document.body, handler);
|
|
160
|
-
}
|
|
161
|
-
}, [wrapperRef]);
|
|
162
162
|
const {
|
|
163
163
|
title,
|
|
164
164
|
introduction,
|
|
@@ -168,55 +168,48 @@ const Article = _ref4 => {
|
|
|
168
168
|
copyright
|
|
169
169
|
} = article;
|
|
170
170
|
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;
|
|
171
|
-
return (0, _jsxRuntime.
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
children: (0, _jsxRuntime.jsx)(_MessageBox.default, {
|
|
181
|
-
links: messageBoxLinks,
|
|
182
|
-
children: messages.messageBox
|
|
183
|
-
})
|
|
184
|
-
}), (0, _jsxRuntime.jsxs)(_ArticleHeaderWrapper.default, {
|
|
185
|
-
competenceGoals: competenceGoals,
|
|
186
|
-
children: [heartButton ? (0, _jsxRuntime.jsx)(ArticleFavoritesButtonWrapper, {
|
|
187
|
-
children: heartButton
|
|
188
|
-
}) : null, (0, _jsxRuntime.jsx)(ArticleTitle, {
|
|
189
|
-
id: id,
|
|
190
|
-
icon: icon,
|
|
191
|
-
label: messages.label,
|
|
192
|
-
lang: lang,
|
|
193
|
-
children: title
|
|
194
|
-
}), (0, _jsxRuntime.jsx)(ArticleIntroduction, {
|
|
195
|
-
lang: lang,
|
|
196
|
-
children: introduction
|
|
197
|
-
})]
|
|
198
|
-
})]
|
|
199
|
-
}), (0, _jsxRuntime.jsxs)(_Layout.default, {
|
|
200
|
-
layout: "center",
|
|
201
|
-
children: [notions && showExplainNotions && (0, _jsxRuntime.jsx)(_ArticleNotions.default, {
|
|
202
|
-
buttonOffsetRight: articlePositionRight,
|
|
203
|
-
children: notions
|
|
204
|
-
}), getArticleContent(content, contentTransformed)]
|
|
205
|
-
}), (0, _jsxRuntime.jsx)(_Layout.default, {
|
|
206
|
-
layout: "center",
|
|
207
|
-
children: (0, _jsxRuntime.jsx)(_ArticleByline.default, {
|
|
208
|
-
footnotes: footNotes,
|
|
209
|
-
authors: authors,
|
|
210
|
-
suppliers: copyright === null || copyright === void 0 ? void 0 : copyright.rightsholders,
|
|
211
|
-
published: published,
|
|
212
|
-
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 : "",
|
|
213
|
-
licenseBox: licenseBox
|
|
171
|
+
return (0, _jsxRuntime.jsxs)(ArticleWrapper, {
|
|
172
|
+
modifier: modifier,
|
|
173
|
+
"data-ndla-article": "",
|
|
174
|
+
children: [(0, _jsxRuntime.jsxs)(_Layout.default, {
|
|
175
|
+
layout: "center",
|
|
176
|
+
children: [messages.messageBox && (0, _jsxRuntime.jsx)(MSGboxWrapper, {
|
|
177
|
+
children: (0, _jsxRuntime.jsx)(_MessageBox.default, {
|
|
178
|
+
links: messageBoxLinks,
|
|
179
|
+
children: messages.messageBox
|
|
214
180
|
})
|
|
215
|
-
}), (0, _jsxRuntime.
|
|
216
|
-
|
|
217
|
-
children:
|
|
181
|
+
}), (0, _jsxRuntime.jsxs)(_ArticleHeaderWrapper.default, {
|
|
182
|
+
competenceGoals: competenceGoals,
|
|
183
|
+
children: [heartButton ? (0, _jsxRuntime.jsx)(ArticleFavoritesButtonWrapper, {
|
|
184
|
+
children: heartButton
|
|
185
|
+
}) : null, (0, _jsxRuntime.jsx)(ArticleTitle, {
|
|
186
|
+
id: id,
|
|
187
|
+
icon: icon,
|
|
188
|
+
label: messages.label,
|
|
189
|
+
lang: lang,
|
|
190
|
+
children: title
|
|
191
|
+
}), (0, _jsxRuntime.jsx)(ArticleIntroduction, {
|
|
192
|
+
lang: lang,
|
|
193
|
+
children: introduction
|
|
194
|
+
})]
|
|
218
195
|
})]
|
|
219
|
-
})
|
|
196
|
+
}), (0, _jsxRuntime.jsx)(_Layout.default, {
|
|
197
|
+
layout: "center",
|
|
198
|
+
children: content
|
|
199
|
+
}), (0, _jsxRuntime.jsx)(_Layout.default, {
|
|
200
|
+
layout: "center",
|
|
201
|
+
children: (0, _jsxRuntime.jsx)(_ArticleByline.default, {
|
|
202
|
+
footnotes: footNotes,
|
|
203
|
+
authors: authors,
|
|
204
|
+
suppliers: copyright === null || copyright === void 0 ? void 0 : copyright.rightsholders,
|
|
205
|
+
published: published,
|
|
206
|
+
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 : "",
|
|
207
|
+
licenseBox: licenseBox
|
|
208
|
+
})
|
|
209
|
+
}), (0, _jsxRuntime.jsx)(_Layout.default, {
|
|
210
|
+
layout: "extend",
|
|
211
|
+
children: children
|
|
212
|
+
})]
|
|
220
213
|
});
|
|
221
214
|
};
|
|
222
215
|
exports.Article = Article;
|
|
@@ -4,7 +4,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var
|
|
7
|
+
var _base = _interopRequireDefault(require("@emotion/styled/base"));
|
|
8
|
+
var _core = require("@ndla/core");
|
|
8
9
|
var _jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
9
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
10
11
|
/**
|
|
@@ -15,19 +16,23 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
15
16
|
*
|
|
16
17
|
*/
|
|
17
18
|
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
});
|
|
19
|
+
const StyledHeaderWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
20
|
+
target: "e1daii1f1",
|
|
21
|
+
label: "StyledHeaderWrapper"
|
|
22
|
+
})("margin-bottom:", _core.spacing.normal, ";", _core.mq.range({
|
|
23
|
+
from: _core.breakpoints.tablet
|
|
24
|
+
}), "{margin-bottom:", _core.spacing.large, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQnNDIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86IFJlYWN0Tm9kZTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZEhlYWRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi1ib3R0b206ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbmA7XG5cbmNvbnN0IENvbXBldGVuY2VXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBBcnRpY2xlSGVhZGVyV3JhcHBlciA9ICh7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMgfTogUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyV3JhcHBlcj5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj57Y29tcGV0ZW5jZUdvYWxzfTwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgPC9TdHlsZWRIZWFkZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQXJ0aWNsZUhlYWRlcldyYXBwZXI7XG4iXX0= */"));
|
|
25
|
+
const CompetenceWrapper = /*#__PURE__*/(0, _base.default)("div", {
|
|
26
|
+
target: "e1daii1f0",
|
|
27
|
+
label: "CompetenceWrapper"
|
|
28
|
+
})("margin-top:", _core.spacing.normal, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Qm9DIiwiZmlsZSI6IkFydGljbGVIZWFkZXJXcmFwcGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE2LXByZXNlbnQsIE5ETEEuXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgR1BMdjMgbGljZW5zZSBmb3VuZCBpbiB0aGVcbiAqIExJQ0VOU0UgZmlsZSBpbiB0aGUgcm9vdCBkaXJlY3Rvcnkgb2YgdGhpcyBzb3VyY2UgdHJlZS5cbiAqXG4gKi9cblxuaW1wb3J0IHsgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IGJyZWFrcG9pbnRzLCBtcSwgc3BhY2luZyB9IGZyb20gXCJAbmRsYS9jb3JlXCI7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNvbXBldGVuY2VHb2Fscz86IFJlYWN0Tm9kZTtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZEhlYWRlcldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBtYXJnaW4tYm90dG9tOiAke3NwYWNpbmcubm9ybWFsfTtcbiAgJHttcS5yYW5nZSh7IGZyb206IGJyZWFrcG9pbnRzLnRhYmxldCB9KX0ge1xuICAgIG1hcmdpbi1ib3R0b206ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbmA7XG5cbmNvbnN0IENvbXBldGVuY2VXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLm5vcm1hbH07XG5gO1xuXG5jb25zdCBBcnRpY2xlSGVhZGVyV3JhcHBlciA9ICh7IGNoaWxkcmVuLCBjb21wZXRlbmNlR29hbHMgfTogUHJvcHMpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyV3JhcHBlcj5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDxDb21wZXRlbmNlV3JhcHBlcj57Y29tcGV0ZW5jZUdvYWxzfTwvQ29tcGV0ZW5jZVdyYXBwZXI+XG4gICAgPC9TdHlsZWRIZWFkZXJXcmFwcGVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgQXJ0aWNsZUhlYWRlcldyYXBwZXI7XG4iXX0= */"));
|
|
22
29
|
const ArticleHeaderWrapper = _ref => {
|
|
23
30
|
let {
|
|
24
31
|
children,
|
|
25
32
|
competenceGoals
|
|
26
33
|
} = _ref;
|
|
27
|
-
return (0, _jsxRuntime.jsxs)(
|
|
28
|
-
|
|
29
|
-
children: [children, (0, _jsxRuntime.jsx)("div", {
|
|
30
|
-
...classes("competence"),
|
|
34
|
+
return (0, _jsxRuntime.jsxs)(StyledHeaderWrapper, {
|
|
35
|
+
children: [children, (0, _jsxRuntime.jsx)(CompetenceWrapper, {
|
|
31
36
|
children: competenceGoals
|
|
32
37
|
})]
|
|
33
38
|
});
|
package/lib/Article/index.d.ts
CHANGED
|
@@ -11,4 +11,5 @@ import ArticleFootNotes from "./ArticleFootNotes";
|
|
|
11
11
|
import ArticleHeaderWrapper from "./ArticleHeaderWrapper";
|
|
12
12
|
export { ArticleByline, ArticleFootNotes, ArticleHeaderWrapper, ArticleTitle, ArticleIntroduction, ArticleWrapper };
|
|
13
13
|
export { ArticleParagraph } from "./ArticleParagraph";
|
|
14
|
+
export type { ArticleModifier } from "./Article";
|
|
14
15
|
export default Article;
|