@ndla/ui 55.0.15-alpha.0 → 55.0.16-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/panda.buildinfo.json +18 -13
  2. package/dist/styles.css +74 -54
  3. package/es/Article/ArticleByline.js +80 -47
  4. package/es/Article/ArticleFootNotes.js +31 -19
  5. package/es/ContentTypeBadge/ContentTypeBadgeNew.js +1 -0
  6. package/es/FrontpageArticle/FrontpageArticle.js +1 -2
  7. package/es/index.js +0 -1
  8. package/es/model/ContentType.js +3 -1
  9. package/es/styles.css +74 -54
  10. package/lib/Article/ArticleByline.d.ts +1 -3
  11. package/lib/Article/ArticleByline.js +82 -49
  12. package/lib/Article/ArticleFootNotes.js +31 -20
  13. package/lib/ContentTypeBadge/ContentTypeBadgeNew.d.ts +1 -2
  14. package/lib/ContentTypeBadge/ContentTypeBadgeNew.js +1 -0
  15. package/lib/FrontpageArticle/FrontpageArticle.js +1 -2
  16. package/lib/index.d.ts +0 -1
  17. package/lib/index.js +0 -7
  18. package/lib/model/ContentType.d.ts +1 -0
  19. package/lib/model/ContentType.js +4 -2
  20. package/lib/styles.css +74 -54
  21. package/package.json +2 -3
  22. package/src/Article/ArticleByline.tsx +82 -69
  23. package/src/Article/ArticleFootNotes.tsx +32 -36
  24. package/src/ContentTypeBadge/ContentTypeBadgeNew.tsx +3 -1
  25. package/src/FrontpageArticle/FrontpageArticle.tsx +1 -1
  26. package/src/index.ts +0 -2
  27. package/src/model/ContentType.ts +2 -0
  28. package/es/CreatedBy/CreatedBy.js +0 -73
  29. package/es/CreatedBy/index.js +0 -10
  30. package/lib/CreatedBy/CreatedBy.d.ts +0 -15
  31. package/lib/CreatedBy/CreatedBy.js +0 -78
  32. package/lib/CreatedBy/index.d.ts +0 -9
  33. package/lib/CreatedBy/index.js +0 -16
  34. package/src/CreatedBy/CreatedBy.stories.tsx +0 -36
  35. package/src/CreatedBy/CreatedBy.tsx +0 -63
  36. package/src/CreatedBy/index.ts +0 -11
@@ -4,13 +4,13 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
7
  var _react = require("react");
9
8
  var _reactI18next = require("react-i18next");
10
9
  var _reactRouterDom = require("react-router-dom");
11
- var _accordion = require("@ndla/accordion");
12
- var _core = require("@ndla/core");
10
+ var _common = require("@ndla/icons/common");
13
11
  var _licenses = require("@ndla/licenses");
12
+ var _primitives = require("@ndla/primitives");
13
+ var _jsx2 = require("@ndla/styled-system/jsx");
14
14
  var _ArticleFootNotes = _interopRequireDefault(require("./ArticleFootNotes"));
15
15
  var _LicenseLink = require("../LicenseByline/LicenseLink");
16
16
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
@@ -23,20 +23,39 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
23
23
  *
24
24
  */
25
25
 
26
- const Wrapper = /*#__PURE__*/(0, _base.default)("div", {
27
- target: "eeu23se5",
28
- label: "Wrapper"
29
- })("margin-top:", _core.spacing.normal, ";padding-top:", _core.spacing.normal, ";padding-bottom:", _core.spacing.xsmall, ";border-top:1px solid ", _core.colors.brand.greyLight, ";", _core.fonts.sizes("16px", "24px"), ";font-family:", _core.fonts.sans, ";color:", _core.colors.brand.greyDark, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAoB0B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
30
- const TextWrapper = /*#__PURE__*/(0, _base.default)("div", {
31
- target: "eeu23se4",
32
- label: "TextWrapper"
33
- })("display:flex;justify-content:space-between;width:100%;padding-bottom:", _core.spacing.mediumlarge, ";", _core.mq.range({
34
- until: _core.breakpoints.tabletWide
35
- }), "{flex-direction:column;flex-direction:column-reverse;gap:", _core.spacing.xsmall, ";}&[data-learning-path=\"true\"]{flex-direction:column;flex-direction:column-reverse;gap:", _core.spacing.xsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA8B8B","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
36
- const PrimaryContributorsWrapper = /*#__PURE__*/(0, _base.default)("span", {
37
- target: "eeu23se3",
38
- label: "PrimaryContributorsWrapper"
39
- })("margin-left:", _core.spacing.xxsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AA+C8C","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
26
+ const Wrapper = (0, _jsx2.styled)("div", {
27
+ base: {
28
+ // TODO: Figure out if we want to remove this margin. It's only here to add some gap between the article content and the byline.
29
+ marginBlockStart: "medium",
30
+ paddingBlockStart: "xsmall",
31
+ borderTop: "1px solid",
32
+ borderColor: "stroke.subtle"
33
+ }
34
+ });
35
+
36
+ // TODO: This is designed with 24px of inline padding. If you do this, most bylines will break into two lines.
37
+ // Should reconsider.
38
+ const TextWrapper = (0, _jsx2.styled)("div", {
39
+ base: {
40
+ display: "flex",
41
+ flexDirection: "column-reverse",
42
+ gap: "3xsmall",
43
+ width: "100%",
44
+ justifyContent: "space-between",
45
+ paddingBlock: "xsmall",
46
+ textStyle: "body.medium"
47
+ },
48
+ variants: {
49
+ learningpath: {
50
+ true: {},
51
+ false: {
52
+ tabletWide: {
53
+ flexDirection: "row"
54
+ }
55
+ }
56
+ }
57
+ }
58
+ });
40
59
  const renderContributors = (contributors, t) => {
41
60
  const contributorsArray = contributors.map((contributor, index) => {
42
61
  if (index < 1) return contributor.name;
@@ -61,18 +80,17 @@ const getSuppliersText = (suppliers, t) => {
61
80
  }
62
81
  });
63
82
  };
64
- const LicenseWrapper = /*#__PURE__*/(0, _base.default)("div", {
65
- target: "eeu23se2",
66
- label: "LicenseWrapper"
67
- })("display:flex;gap:", _core.spacing.small, ";padding-right:", _core.spacing.xsmall, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkGiC","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
68
- const StyledAccordionHeader = /*#__PURE__*/(0, _base.default)(_accordion.AccordionHeader, {
69
- target: "eeu23se1",
70
- label: "StyledAccordionHeader"
71
- })("background-color:", _core.colors.brand.lightest, ";", _core.fonts.sizes("16px", "29px"), ";font-weight:", _core.fonts.weight.semibold, ";&[data-background-color=\"white\"][data-state=\"closed\"]{background-color:", _core.colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAwGqD","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
72
- const StyledAccordionContent = /*#__PURE__*/(0, _base.default)(_accordion.AccordionContent, {
73
- target: "eeu23se0",
74
- label: "StyledAccordionContent"
75
- })("&[data-background-color=\"white\"]{background-color:", _core.colors.background.default, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ArticleByline.tsx"],"names":[],"mappings":"AAkHuD","file":"ArticleByline.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport { TFunction } from \"i18next\";\nimport { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport { useTranslation } from \"react-i18next\";\nimport { useLocation } from \"react-router-dom\";\nimport styled from \"@emotion/styled\";\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from \"@ndla/accordion\";\nimport { breakpoints, colors, fonts, mq, spacing } from \"@ndla/core\";\nimport { getLicenseByAbbreviation } from \"@ndla/licenses\";\nimport ArticleFootNotes from \"./ArticleFootNotes\";\nimport { LicenseLink } from \"../LicenseByline/LicenseLink\";\nimport { FootNote } from \"../types\";\n\nconst Wrapper = styled.div`\n  margin-top: ${spacing.normal};\n  padding-top: ${spacing.normal};\n  padding-bottom: ${spacing.xsmall};\n  border-top: 1px solid ${colors.brand.greyLight};\n  ${fonts.sizes(\"16px\", \"24px\")};\n  font-family: ${fonts.sans};\n  color: ${colors.brand.greyDark};\n`;\n\nconst TextWrapper = styled.div`\n  display: flex;\n  justify-content: space-between;\n  width: 100%;\n  padding-bottom: ${spacing.mediumlarge};\n  ${mq.range({ until: breakpoints.tabletWide })} {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n  &[data-learning-path=\"true\"] {\n    flex-direction: column;\n    flex-direction: column-reverse;\n    gap: ${spacing.xsmall};\n  }\n`;\n\nconst PrimaryContributorsWrapper = styled.span`\n  margin-left: ${spacing.xxsmall};\n`;\n\ntype AuthorProps = {\n  name: string;\n};\n\ntype SupplierProps = {\n  name: string;\n};\n\ntype AccordionHeaderVariants = \"white\" | \"blue\";\n\ntype Props = {\n  authors?: AuthorProps[];\n  suppliers?: SupplierProps[];\n  published?: string;\n  license?: string;\n  licenseBox?: ReactNode;\n  locale?: string;\n  footnotes?: FootNote[];\n  accordionHeaderVariant?: AccordionHeaderVariants;\n  displayByline?: boolean;\n  bylineType?: \"article\" | \"learningPath\";\n};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t(\"article.conjunction\")} ` : \", \";\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join(\"\");\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return \"\";\n  }\n  return suppliers.length > 1\n    ? t(\"article.multipleSuppliersLabel\", {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t(\"article.supplierLabel\", {\n        name: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      });\n};\n\nconst LicenseWrapper = styled.div`\n  display: flex;\n  gap: ${spacing.small};\n  padding-right: ${spacing.xsmall};\n`;\n\nconst StyledAccordionHeader = styled(AccordionHeader)`\n  background-color: ${colors.brand.lightest};\n  ${fonts.sizes(\"16px\", \"29px\")};\n  font-weight: ${fonts.weight.semibold};\n\n  &[data-background-color=\"white\"][data-state=\"closed\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst StyledAccordionContent = styled(AccordionContent)`\n  &[data-background-color=\"white\"] {\n    background-color: ${colors.background.default};\n  }\n`;\n\nconst refRegexp = /note\\d/;\nconst footnotesAccordionId = \"footnotes\";\n\nconst ArticleByline = ({\n  authors = [],\n  suppliers = [],\n  footnotes,\n  license: licenseString,\n  licenseBox,\n  published,\n  locale,\n  accordionHeaderVariant = \"blue\",\n  displayByline = true,\n  bylineType = \"article\",\n}: Props) => {\n  const { t } = useTranslation();\n  const { pathname } = useLocation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\n  const accordionItemValue = \"rulesForUse\";\n\n  const onHashChange = useCallback(\n    (e: HashChangeEvent) => {\n      const hash = e.newURL.split(\"#\")[1];\n      if (hash.match(refRegexp) && !openAccordions.includes(footnotesAccordionId)) {\n        setOpenAccordions([...openAccordions, footnotesAccordionId]);\n        const el = document.getElementById(`#${hash}`);\n        el?.click();\n        el?.focus();\n      }\n    },\n    [openAccordions],\n  );\n\n  useEffect(() => {\n    setOpenAccordions((prev) => prev.filter((state) => state !== accordionItemValue));\n  }, [pathname]);\n\n  useEffect(() => {\n    window.addEventListener(\"hashchange\", onHashChange);\n    return () => window.removeEventListener(\"hashchange\", onHashChange);\n  }, [onHashChange]);\n\n  const license = licenseString && getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      {displayByline && (\n        <TextWrapper data-learning-path={bylineType === \"learningPath\"}>\n          <LicenseWrapper>\n            {license && <LicenseLink license={license} />}\n            {showPrimaryContributors && (\n              <PrimaryContributorsWrapper>\n                {authors.length > 0 &&\n                  `${t(\"article.authorsLabel\", {\n                    names: renderContributors(authors, t),\n                    interpolation: { escapeValue: false },\n                  })}. `}\n                {getSuppliersText(suppliers, t)}\n              </PrimaryContributorsWrapper>\n            )}\n          </LicenseWrapper>\n          <div>\n            {t(`${bylineType}.lastUpdated`)} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value={accordionItemValue}>\n            <StyledAccordionHeader headingLevel=\"h2\" data-background-color={accordionHeaderVariant}>\n              {t(\"article.useContent\")}\n            </StyledAccordionHeader>\n            <StyledAccordionContent data-background-color={accordionHeaderVariant}>{licenseBox}</StyledAccordionContent>\n          </AccordionItem>\n        )}\n\n        {!!footnotes?.length && (\n          <AccordionItem value={footnotesAccordionId}>\n            <StyledAccordionHeader headingLevel=\"h2\">{t(\"article.footnotes\")}</StyledAccordionHeader>\n            <StyledAccordionContent forceMount data-background-color={accordionHeaderVariant}>\n              <ArticleFootNotes footNotes={footnotes} />\n            </StyledAccordionContent>\n          </AccordionItem>\n        )}\n      </AccordionRoot>\n    </Wrapper>\n  );\n};\n\nexport default ArticleByline;\n"]} */"));
83
+ const LicenseWrapper = (0, _jsx2.styled)("div", {
84
+ base: {
85
+ display: "flex",
86
+ gap: "xsmall"
87
+ }
88
+ });
89
+ const StyledAccordionRoot = (0, _jsx2.styled)(_primitives.AccordionRoot, {
90
+ base: {
91
+ paddingBlockStart: "xxlarge"
92
+ }
93
+ });
76
94
  const refRegexp = /note\d/;
77
95
  const footnotesAccordionId = "footnotes";
78
96
  const ArticleByline = _ref => {
@@ -84,7 +102,6 @@ const ArticleByline = _ref => {
84
102
  licenseBox,
85
103
  published,
86
104
  locale,
87
- accordionHeaderVariant = "blue",
88
105
  displayByline = true,
89
106
  bylineType = "article"
90
107
  } = _ref;
@@ -116,11 +133,11 @@ const ArticleByline = _ref => {
116
133
  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;
117
134
  return (0, _jsxRuntime.jsxs)(Wrapper, {
118
135
  children: [displayByline && (0, _jsxRuntime.jsxs)(TextWrapper, {
119
- "data-learning-path": bylineType === "learningPath",
136
+ learningpath: bylineType === "learningPath",
120
137
  children: [(0, _jsxRuntime.jsxs)(LicenseWrapper, {
121
138
  children: [license && (0, _jsxRuntime.jsx)(_LicenseLink.LicenseLink, {
122
139
  license: license
123
- }), showPrimaryContributors && (0, _jsxRuntime.jsxs)(PrimaryContributorsWrapper, {
140
+ }), showPrimaryContributors && (0, _jsxRuntime.jsxs)("span", {
124
141
  children: [authors.length > 0 && `${t("article.authorsLabel", {
125
142
  names: renderContributors(authors, t),
126
143
  interpolation: {
@@ -131,28 +148,44 @@ const ArticleByline = _ref => {
131
148
  }), (0, _jsxRuntime.jsxs)("div", {
132
149
  children: [t(`${bylineType}.lastUpdated`), " ", published]
133
150
  })]
134
- }), (0, _jsxRuntime.jsxs)(_accordion.AccordionRoot, {
135
- type: "multiple",
136
- onValueChange: setOpenAccordions,
151
+ }), (0, _jsxRuntime.jsxs)(StyledAccordionRoot, {
152
+ multiple: true,
137
153
  value: openAccordions,
138
- children: [licenseBox && (0, _jsxRuntime.jsxs)(_accordion.AccordionItem, {
154
+ onValueChange: details => setOpenAccordions(details.value),
155
+ children: [licenseBox && (0, _jsxRuntime.jsxs)(_primitives.AccordionItem, {
139
156
  value: accordionItemValue,
140
- children: [(0, _jsxRuntime.jsx)(StyledAccordionHeader, {
141
- headingLevel: "h2",
142
- "data-background-color": accordionHeaderVariant,
143
- children: t("article.useContent")
144
- }), (0, _jsxRuntime.jsx)(StyledAccordionContent, {
145
- "data-background-color": accordionHeaderVariant,
157
+ children: [(0, _jsxRuntime.jsxs)(_primitives.AccordionItemTrigger, {
158
+ children: [(0, _jsxRuntime.jsx)(_primitives.Heading, {
159
+ asChild: true,
160
+ consumeCss: true,
161
+ textStyle: "label.medium",
162
+ fontWeight: "bold",
163
+ children: (0, _jsxRuntime.jsx)("h2", {
164
+ children: t("article.useContent")
165
+ })
166
+ }), (0, _jsxRuntime.jsx)(_primitives.AccordionItemIndicator, {
167
+ asChild: true,
168
+ children: (0, _jsxRuntime.jsx)(_common.ChevronDown, {})
169
+ })]
170
+ }), (0, _jsxRuntime.jsx)(_primitives.AccordionItemContent, {
146
171
  children: licenseBox
147
172
  })]
148
- }), !!footnotes?.length && (0, _jsxRuntime.jsxs)(_accordion.AccordionItem, {
173
+ }), !!footnotes?.length && (0, _jsxRuntime.jsxs)(_primitives.AccordionItem, {
149
174
  value: footnotesAccordionId,
150
- children: [(0, _jsxRuntime.jsx)(StyledAccordionHeader, {
151
- headingLevel: "h2",
152
- children: t("article.footnotes")
153
- }), (0, _jsxRuntime.jsx)(StyledAccordionContent, {
154
- forceMount: true,
155
- "data-background-color": accordionHeaderVariant,
175
+ children: [(0, _jsxRuntime.jsxs)(_primitives.AccordionItemTrigger, {
176
+ children: [(0, _jsxRuntime.jsx)(_primitives.Heading, {
177
+ asChild: true,
178
+ consumeCss: true,
179
+ textStyle: "label.medium",
180
+ fontWeight: "bold",
181
+ children: (0, _jsxRuntime.jsx)("h2", {
182
+ children: t("article.footnotes")
183
+ })
184
+ }), (0, _jsxRuntime.jsx)(_primitives.AccordionItemIndicator, {
185
+ asChild: true,
186
+ children: (0, _jsxRuntime.jsx)(_common.ChevronDown, {})
187
+ })]
188
+ }), (0, _jsxRuntime.jsx)(_primitives.AccordionItemContent, {
156
189
  children: (0, _jsxRuntime.jsx)(_ArticleFootNotes.default, {
157
190
  footNotes: footnotes
158
191
  })
@@ -4,10 +4,9 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _core = require("@ndla/core");
7
+ var _primitives = require("@ndla/primitives");
8
+ var _jsx2 = require("@ndla/styled-system/jsx");
9
9
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
10
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
11
10
  /**
12
11
  * Copyright (c) 2017-present, NDLA.
13
12
  *
@@ -17,32 +16,44 @@ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e
17
16
  */
18
17
 
19
18
  const citeDetailString = description => description ? `${description}. ` : "";
20
- const Cite = /*#__PURE__*/(0, _base.default)("cite", {
21
- target: "eds1c3s1",
22
- label: "Cite"
23
- })("display:flex;gap:", _core.spacing.small, ";a{box-shadow:none;text-decoration:underline;text-underline-offset:", _core.spacing.xxsmall, ";&:hover,&:focus-visible{text-decoration:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVGb290Tm90ZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCd0IiLCJmaWxlIjoiQXJ0aWNsZUZvb3ROb3Rlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgY29sb3JzLCBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEZvb3ROb3RlIGFzIEZvb3ROb3RlVHlwZSB9IGZyb20gXCIuLi90eXBlc1wiO1xuXG5jb25zdCBjaXRlRGV0YWlsU3RyaW5nID0gKGRlc2NyaXB0aW9uOiBzdHJpbmcgfCB1bmRlZmluZWQpID0+IChkZXNjcmlwdGlvbiA/IGAke2Rlc2NyaXB0aW9ufS4gYCA6IFwiXCIpO1xuXG50eXBlIEZvb3ROb3RlUHJvcHMgPSB7XG4gIGZvb3ROb3RlOiBGb290Tm90ZVR5cGU7XG59O1xuXG5jb25zdCBDaXRlID0gc3R5bGVkLmNpdGVgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgYSB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB0ZXh0LXVuZGVybGluZS1vZmZzZXQ6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgICAmOmhvdmVyLFxuICAgICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBGb290Tm90ZSA9ICh7IGZvb3ROb3RlIH06IEZvb3ROb3RlUHJvcHMpID0+IChcbiAgPGxpPlxuICAgIDxDaXRlIGlkPXtgbm90ZSR7Zm9vdE5vdGUucmVmfWB9PlxuICAgICAgPGEgaHJlZj17YCNyZWYke2Zvb3ROb3RlLnJlZn1gfSB0YXJnZXQ9XCJfc2VsZlwiPlxuICAgICAgICB7Zm9vdE5vdGUucmVmfVxuICAgICAgPC9hPlxuICAgICAge2DCqyR7Zm9vdE5vdGUudGl0bGV9wrsuICR7Zm9vdE5vdGUuYXV0aG9ycy5qb2luKFwiIFwiKX0uICR7Y2l0ZURldGFpbFN0cmluZyhmb290Tm90ZS5lZGl0aW9uKX0ke2NpdGVEZXRhaWxTdHJpbmcoXG4gICAgICAgIGZvb3ROb3RlLnB1Ymxpc2hlcixcbiAgICAgICl9JHtmb290Tm90ZS55ZWFyfS4gYH1cbiAgICAgIHtmb290Tm90ZS51cmwgPyAoXG4gICAgICAgIDxhIGhyZWY9e2Zvb3ROb3RlLnVybH0+XG4gICAgICAgICAge2Zvb3ROb3RlLnVybH1cbiAgICAgICAgICB7XCIuXCJ9XG4gICAgICAgIDwvYT5cbiAgICAgICkgOiBudWxsfVxuICAgIDwvQ2l0ZT5cbiAgPC9saT5cbik7XG5cbnR5cGUgQXJ0aWNsZUZvb3ROb3Rlc1Byb3BzID0ge1xuICBmb290Tm90ZXM6IEFycmF5PEZvb3ROb3RlVHlwZT47XG59O1xuXG5jb25zdCBGb290bm90ZUxpc3QgPSBzdHlsZWQub2xgXG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHQubGlnaHR9O1xuYDtcblxuY29uc3QgQXJ0aWNsZUZvb3ROb3RlcyA9ICh7IGZvb3ROb3RlcyB9OiBBcnRpY2xlRm9vdE5vdGVzUHJvcHMpID0+IChcbiAgPEZvb3Rub3RlTGlzdD5cbiAgICB7Zm9vdE5vdGVzLm1hcCgoZm9vdE5vdGUpID0+IChcbiAgICAgIDxGb290Tm90ZSBrZXk9e2Zvb3ROb3RlLnJlZn0gZm9vdE5vdGU9e2Zvb3ROb3RlfSAvPlxuICAgICkpfVxuICA8L0Zvb3Rub3RlTGlzdD5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IEFydGljbGVGb290Tm90ZXM7XG4iXX0= */"));
19
+ const StyledCite = (0, _jsx2.styled)("cite", {
20
+ base: {
21
+ display: "flex",
22
+ alignItems: "center",
23
+ gap: "xsmall"
24
+ }
25
+ });
24
26
  const FootNote = _ref => {
25
27
  let {
26
28
  footNote
27
29
  } = _ref;
28
30
  return (0, _jsxRuntime.jsx)("li", {
29
- children: (0, _jsxRuntime.jsxs)(Cite, {
31
+ children: (0, _jsxRuntime.jsx)(_primitives.Text, {
30
32
  id: `note${footNote.ref}`,
31
- children: [(0, _jsxRuntime.jsx)("a", {
32
- href: `#ref${footNote.ref}`,
33
- target: "_self",
34
- children: footNote.ref
35
- }), `«${footNote.title}». ${footNote.authors.join(" ")}. ${citeDetailString(footNote.edition)}${citeDetailString(footNote.publisher)}${footNote.year}. `, footNote.url ? (0, _jsxRuntime.jsxs)("a", {
36
- href: footNote.url,
37
- children: [footNote.url, "."]
38
- }) : null]
33
+ asChild: true,
34
+ consumeCss: true,
35
+ textStyle: "body.medium",
36
+ children: (0, _jsxRuntime.jsxs)(StyledCite, {
37
+ children: [(0, _jsxRuntime.jsx)("a", {
38
+ href: `#ref${footNote.ref}`,
39
+ target: "_self",
40
+ children: footNote.ref
41
+ }), `«${footNote.title}». ${footNote.authors.join(" ")}. ${citeDetailString(footNote.edition)}${citeDetailString(footNote.publisher)}${footNote.year}. `, footNote.url ? (0, _jsxRuntime.jsxs)("a", {
42
+ href: footNote.url,
43
+ children: [footNote.url, "."]
44
+ }) : null]
45
+ })
39
46
  })
40
47
  });
41
48
  };
42
- const FootnoteList = /*#__PURE__*/(0, _base.default)("ol", {
43
- target: "eds1c3s0",
44
- label: "FootnoteList"
45
- })("margin:0;display:flex;flex-direction:column;list-style:none;padding:", _core.spacing.small, ";color:", _core.colors.text.light, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFydGljbGVGb290Tm90ZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVEOEIiLCJmaWxlIjoiQXJ0aWNsZUZvb3ROb3Rlcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgY29sb3JzLCBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IEZvb3ROb3RlIGFzIEZvb3ROb3RlVHlwZSB9IGZyb20gXCIuLi90eXBlc1wiO1xuXG5jb25zdCBjaXRlRGV0YWlsU3RyaW5nID0gKGRlc2NyaXB0aW9uOiBzdHJpbmcgfCB1bmRlZmluZWQpID0+IChkZXNjcmlwdGlvbiA/IGAke2Rlc2NyaXB0aW9ufS4gYCA6IFwiXCIpO1xuXG50eXBlIEZvb3ROb3RlUHJvcHMgPSB7XG4gIGZvb3ROb3RlOiBGb290Tm90ZVR5cGU7XG59O1xuXG5jb25zdCBDaXRlID0gc3R5bGVkLmNpdGVgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtzcGFjaW5nLnNtYWxsfTtcbiAgYSB7XG4gICAgYm94LXNoYWRvdzogbm9uZTtcbiAgICB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtcbiAgICB0ZXh0LXVuZGVybGluZS1vZmZzZXQ6ICR7c3BhY2luZy54eHNtYWxsfTtcbiAgICAmOmhvdmVyLFxuICAgICY6Zm9jdXMtdmlzaWJsZSB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgfVxuICB9XG5gO1xuXG5jb25zdCBGb290Tm90ZSA9ICh7IGZvb3ROb3RlIH06IEZvb3ROb3RlUHJvcHMpID0+IChcbiAgPGxpPlxuICAgIDxDaXRlIGlkPXtgbm90ZSR7Zm9vdE5vdGUucmVmfWB9PlxuICAgICAgPGEgaHJlZj17YCNyZWYke2Zvb3ROb3RlLnJlZn1gfSB0YXJnZXQ9XCJfc2VsZlwiPlxuICAgICAgICB7Zm9vdE5vdGUucmVmfVxuICAgICAgPC9hPlxuICAgICAge2DCqyR7Zm9vdE5vdGUudGl0bGV9wrsuICR7Zm9vdE5vdGUuYXV0aG9ycy5qb2luKFwiIFwiKX0uICR7Y2l0ZURldGFpbFN0cmluZyhmb290Tm90ZS5lZGl0aW9uKX0ke2NpdGVEZXRhaWxTdHJpbmcoXG4gICAgICAgIGZvb3ROb3RlLnB1Ymxpc2hlcixcbiAgICAgICl9JHtmb290Tm90ZS55ZWFyfS4gYH1cbiAgICAgIHtmb290Tm90ZS51cmwgPyAoXG4gICAgICAgIDxhIGhyZWY9e2Zvb3ROb3RlLnVybH0+XG4gICAgICAgICAge2Zvb3ROb3RlLnVybH1cbiAgICAgICAgICB7XCIuXCJ9XG4gICAgICAgIDwvYT5cbiAgICAgICkgOiBudWxsfVxuICAgIDwvQ2l0ZT5cbiAgPC9saT5cbik7XG5cbnR5cGUgQXJ0aWNsZUZvb3ROb3Rlc1Byb3BzID0ge1xuICBmb290Tm90ZXM6IEFycmF5PEZvb3ROb3RlVHlwZT47XG59O1xuXG5jb25zdCBGb290bm90ZUxpc3QgPSBzdHlsZWQub2xgXG4gIG1hcmdpbjogMDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgcGFkZGluZzogJHtzcGFjaW5nLnNtYWxsfTtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHQubGlnaHR9O1xuYDtcblxuY29uc3QgQXJ0aWNsZUZvb3ROb3RlcyA9ICh7IGZvb3ROb3RlcyB9OiBBcnRpY2xlRm9vdE5vdGVzUHJvcHMpID0+IChcbiAgPEZvb3Rub3RlTGlzdD5cbiAgICB7Zm9vdE5vdGVzLm1hcCgoZm9vdE5vdGUpID0+IChcbiAgICAgIDxGb290Tm90ZSBrZXk9e2Zvb3ROb3RlLnJlZn0gZm9vdE5vdGU9e2Zvb3ROb3RlfSAvPlxuICAgICkpfVxuICA8L0Zvb3Rub3RlTGlzdD5cbik7XG5cbmV4cG9ydCBkZWZhdWx0IEFydGljbGVGb290Tm90ZXM7XG4iXX0= */"));
49
+ const FootnoteList = (0, _jsx2.styled)("ol", {
50
+ base: {
51
+ display: "flex",
52
+ flexDirection: "column",
53
+ gap: "medium",
54
+ listStyle: "none"
55
+ }
56
+ });
46
57
  const ArticleFootNotes = _ref2 => {
47
58
  let {
48
59
  footNotes
@@ -11,7 +11,6 @@ import * as contentTypes from "../model/ContentType";
11
11
  export interface ContentTypeBadgeProps extends Omit<BadgeProps, "colorTheme"> {
12
12
  contentType: ContentType | undefined;
13
13
  }
14
- type ContentType = typeof contentTypes.SUBJECT_MATERIAL | typeof contentTypes.TASKS_AND_ACTIVITIES | typeof contentTypes.ASSESSMENT_RESOURCES | typeof contentTypes.SUBJECT | typeof contentTypes.SOURCE_MATERIAL | typeof contentTypes.LEARNING_PATH | typeof contentTypes.TOPIC | typeof contentTypes.MULTIDISCIPLINARY_TOPIC | typeof contentTypes.CONCEPT | typeof contentTypes.EXTERNAL | typeof contentTypes.IMAGE | typeof contentTypes.AUDIO | typeof contentTypes.VIDEO | typeof contentTypes.MISSING | (string & {});
14
+ export type ContentType = typeof contentTypes.SUBJECT_MATERIAL | typeof contentTypes.TASKS_AND_ACTIVITIES | typeof contentTypes.ASSESSMENT_RESOURCES | typeof contentTypes.SUBJECT | typeof contentTypes.SOURCE_MATERIAL | typeof contentTypes.LEARNING_PATH | typeof contentTypes.TOPIC | typeof contentTypes.MULTIDISCIPLINARY_TOPIC | typeof contentTypes.CONCEPT | typeof contentTypes.EXTERNAL | typeof contentTypes.IMAGE | typeof contentTypes.AUDIO | typeof contentTypes.VIDEO | typeof contentTypes.MISSING | typeof contentTypes.PODCAST | (string & {});
15
15
  export declare const contentTypeToBadgeVariantMap: Record<ContentType, BadgeVariant>;
16
16
  export declare const ContentTypeBadge: import("react").ForwardRefExoticComponent<ContentTypeBadgeProps & import("react").RefAttributes<HTMLDivElement>>;
17
- export {};
@@ -35,6 +35,7 @@ const contentTypeToBadgeVariantMap = exports.contentTypeToBadgeVariantMap = {
35
35
  // TODO: Verify resourceEmbedTypeMapping colors
36
36
  [contentTypes.IMAGE]: "brand1",
37
37
  [contentTypes.AUDIO]: "brand1",
38
+ [contentTypes.PODCAST]: "brand1",
38
39
  [contentTypes.VIDEO]: "brand1",
39
40
  [contentTypes.MISSING]: "neutral"
40
41
  };
@@ -25,7 +25,7 @@ const WIDE_FRONTPAGE_ARTICLE_MAX_WIDTH = exports.WIDE_FRONTPAGE_ARTICLE_MAX_WIDT
25
25
  const StyledArticle = /*#__PURE__*/(0, _base.default)("article", {
26
26
  target: "e10a6yg80",
27
27
  label: "StyledArticle"
28
- })("width:100%;max-width:773px;h2[id]{margin-top:", _core.spacing.large, ";}div[data-type=\"campaign-block\"]{margin:", _core.spacing.large, " 0px;}div[data-type=\"grid\"]{h2,h3,h4{margin-top:0px;}}div[data-type=\"grid\"]+div[data-type=\"grid\"]{margin-top:", _core.spacing.xxlarge, ";}&[data-wide=\"true\"]{max-width:1100px;h2[id]{margin-top:", _core.spacing.xxlarge, ";}div[data-type=\"campaign-block\"]{margin:", _core.spacing.xxlarge, " 0px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCb0MiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IHVzZUNvbXBvbmVudFNpemUgfSBmcm9tIFwiQG5kbGEvaG9va3NcIjtcbmltcG9ydCB7IEhlYWRpbmcsIFRleHQgfSBmcm9tIFwiQG5kbGEvdHlwb2dyYXBoeVwiO1xuaW1wb3J0IHsgQXJ0aWNsZUJ5bGluZSB9IGZyb20gXCIuLi9BcnRpY2xlXCI7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSBcIi4uL3R5cGVzXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGFydGljbGU6IE9taXQ8QXJ0aWNsZSwgXCJmb290Tm90ZXNcIj47XG4gIGlkOiBzdHJpbmc7XG4gIGlzV2lkZT86IGJvb2xlYW47XG4gIGxpY2Vuc2VCb3g/OiBSZWFjdE5vZGU7XG4gIGxhbmc/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBGUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSBcIjc3M3B4XCI7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSBcIjExMDBweFwiO1xuXG5jb25zdCBTdHlsZWRBcnRpY2xlID0gc3R5bGVkLmFydGljbGVgXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDc3M3B4O1xuICBoMltpZF0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT1cImNhbXBhaWduLWJsb2NrXCJdIHtcbiAgICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMHB4O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9XCJncmlkXCJdIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG5cbiAgZGl2W2RhdGEtdHlwZT1cImdyaWRcIl0gKyBkaXZbZGF0YS10eXBlPVwiZ3JpZFwiXSB7XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnh4bGFyZ2V9O1xuICB9XG5cbiAgJltkYXRhLXdpZGU9XCJ0cnVlXCJdIHtcbiAgICBtYXgtd2lkdGg6IDExMDBweDtcbiAgICBoMltpZF0ge1xuICAgICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnh4bGFyZ2V9O1xuICAgIH1cbiAgICBkaXZbZGF0YS10eXBlPVwiY2FtcGFpZ24tYmxvY2tcIl0ge1xuICAgICAgbWFyZ2luOiAke3NwYWNpbmcueHhsYXJnZX0gMHB4O1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEZyb250cGFnZUFydGljbGUgPSAoeyBhcnRpY2xlLCBpZCwgaXNXaWRlLCBsaWNlbnNlQm94LCBsYW5nIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgaGVpZ2h0ID0gMCB9ID0gdXNlQ29tcG9uZW50U2l6ZShcIm1hc3RoZWFkXCIpO1xuICBjb25zdCBjc3NWYXJzID0gdXNlTWVtbygoKSA9PiAoeyBcIi0tbWFzdGhlYWQtaGVpZ2h0XCI6IGAke2hlaWdodH1weGAgfSkgYXMgdW5rbm93biBhcyBDU1NQcm9wZXJ0aWVzLCBbaGVpZ2h0XSk7XG4gIGNvbnN0IHsgdGl0bGUsIGludHJvZHVjdGlvbiwgY29udGVudCB9ID0gYXJ0aWNsZTtcblxuICBpZiAoaXNXaWRlKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRBcnRpY2xlIGRhdGEtd2lkZT17aXNXaWRlfSBzdHlsZT17Y3NzVmFyc30gaWQ9e2lkfT5cbiAgICAgICAge2NvbnRlbnR9XG4gICAgICA8L1N0eWxlZEFydGljbGU+XG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGUgc3R5bGU9e2Nzc1ZhcnN9PlxuICAgICAgPEhlYWRpbmcgaWQ9e2lkfSBoZWFkaW5nU3R5bGU9XCJoMS1yZXNvdXJjZVwiIGVsZW1lbnQ9XCJoMVwiIG1hcmdpbj1cIm5vcm1hbFwiIHRhYkluZGV4PXstMX0gbGFuZz17bGFuZ30+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvSGVhZGluZz5cbiAgICAgIDxUZXh0IHRleHRTdHlsZT1cImluZ3Jlc3NcIiBlbGVtZW50PVwiZGl2XCIgbGFuZz17bGFuZ30+XG4gICAgICAgIHtpbnRyb2R1Y3Rpb259XG4gICAgICA8L1RleHQ+XG4gICAgICB7Y29udGVudH1cbiAgICAgIDxBcnRpY2xlQnlsaW5lIGFjY29yZGlvbkhlYWRlclZhcmlhbnQ9e1wid2hpdGVcIn0gbGljZW5zZUJveD17bGljZW5zZUJveH0gZGlzcGxheUJ5bGluZT17ZmFsc2V9IC8+XG4gICAgPC9TdHlsZWRBcnRpY2xlPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRnJvbnRwYWdlQXJ0aWNsZTtcbiJdfQ== */"));
28
+ })("width:100%;max-width:773px;h2[id]{margin-top:", _core.spacing.large, ";}div[data-type=\"campaign-block\"]{margin:", _core.spacing.large, " 0px;}div[data-type=\"grid\"]{h2,h3,h4{margin-top:0px;}}div[data-type=\"grid\"]+div[data-type=\"grid\"]{margin-top:", _core.spacing.xxlarge, ";}&[data-wide=\"true\"]{max-width:1100px;h2[id]{margin-top:", _core.spacing.xxlarge, ";}div[data-type=\"campaign-block\"]{margin:", _core.spacing.xxlarge, " 0px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkZyb250cGFnZUFydGljbGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCb0MiLCJmaWxlIjoiRnJvbnRwYWdlQXJ0aWNsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyMy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCB7IENTU1Byb3BlcnRpZXMsIFJlYWN0Tm9kZSwgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBzcGFjaW5nIH0gZnJvbSBcIkBuZGxhL2NvcmVcIjtcbmltcG9ydCB7IHVzZUNvbXBvbmVudFNpemUgfSBmcm9tIFwiQG5kbGEvaG9va3NcIjtcbmltcG9ydCB7IEhlYWRpbmcsIFRleHQgfSBmcm9tIFwiQG5kbGEvdHlwb2dyYXBoeVwiO1xuaW1wb3J0IHsgQXJ0aWNsZUJ5bGluZSB9IGZyb20gXCIuLi9BcnRpY2xlXCI7XG5pbXBvcnQgeyBBcnRpY2xlIH0gZnJvbSBcIi4uL3R5cGVzXCI7XG5cbmludGVyZmFjZSBQcm9wcyB7XG4gIGFydGljbGU6IE9taXQ8QXJ0aWNsZSwgXCJmb290Tm90ZXNcIj47XG4gIGlkOiBzdHJpbmc7XG4gIGlzV2lkZT86IGJvb2xlYW47XG4gIGxpY2Vuc2VCb3g/OiBSZWFjdE5vZGU7XG4gIGxhbmc/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBGUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSBcIjc3M3B4XCI7XG5leHBvcnQgY29uc3QgV0lERV9GUk9OVFBBR0VfQVJUSUNMRV9NQVhfV0lEVEggPSBcIjExMDBweFwiO1xuXG5jb25zdCBTdHlsZWRBcnRpY2xlID0gc3R5bGVkLmFydGljbGVgXG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDc3M3B4O1xuICBoMltpZF0ge1xuICAgIG1hcmdpbi10b3A6ICR7c3BhY2luZy5sYXJnZX07XG4gIH1cbiAgZGl2W2RhdGEtdHlwZT1cImNhbXBhaWduLWJsb2NrXCJdIHtcbiAgICBtYXJnaW46ICR7c3BhY2luZy5sYXJnZX0gMHB4O1xuICB9XG4gIGRpdltkYXRhLXR5cGU9XCJncmlkXCJdIHtcbiAgICBoMixcbiAgICBoMyxcbiAgICBoNCB7XG4gICAgICBtYXJnaW4tdG9wOiAwcHg7XG4gICAgfVxuICB9XG5cbiAgZGl2W2RhdGEtdHlwZT1cImdyaWRcIl0gKyBkaXZbZGF0YS10eXBlPVwiZ3JpZFwiXSB7XG4gICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnh4bGFyZ2V9O1xuICB9XG5cbiAgJltkYXRhLXdpZGU9XCJ0cnVlXCJdIHtcbiAgICBtYXgtd2lkdGg6IDExMDBweDtcbiAgICBoMltpZF0ge1xuICAgICAgbWFyZ2luLXRvcDogJHtzcGFjaW5nLnh4bGFyZ2V9O1xuICAgIH1cbiAgICBkaXZbZGF0YS10eXBlPVwiY2FtcGFpZ24tYmxvY2tcIl0ge1xuICAgICAgbWFyZ2luOiAke3NwYWNpbmcueHhsYXJnZX0gMHB4O1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEZyb250cGFnZUFydGljbGUgPSAoeyBhcnRpY2xlLCBpZCwgaXNXaWRlLCBsaWNlbnNlQm94LCBsYW5nIH06IFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgaGVpZ2h0ID0gMCB9ID0gdXNlQ29tcG9uZW50U2l6ZShcIm1hc3RoZWFkXCIpO1xuICBjb25zdCBjc3NWYXJzID0gdXNlTWVtbygoKSA9PiAoeyBcIi0tbWFzdGhlYWQtaGVpZ2h0XCI6IGAke2hlaWdodH1weGAgfSkgYXMgdW5rbm93biBhcyBDU1NQcm9wZXJ0aWVzLCBbaGVpZ2h0XSk7XG4gIGNvbnN0IHsgdGl0bGUsIGludHJvZHVjdGlvbiwgY29udGVudCB9ID0gYXJ0aWNsZTtcblxuICBpZiAoaXNXaWRlKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRBcnRpY2xlIGRhdGEtd2lkZT17aXNXaWRlfSBzdHlsZT17Y3NzVmFyc30gaWQ9e2lkfT5cbiAgICAgICAge2NvbnRlbnR9XG4gICAgICA8L1N0eWxlZEFydGljbGU+XG4gICAgKTtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEFydGljbGUgc3R5bGU9e2Nzc1ZhcnN9PlxuICAgICAgPEhlYWRpbmcgaWQ9e2lkfSBoZWFkaW5nU3R5bGU9XCJoMS1yZXNvdXJjZVwiIGVsZW1lbnQ9XCJoMVwiIG1hcmdpbj1cIm5vcm1hbFwiIHRhYkluZGV4PXstMX0gbGFuZz17bGFuZ30+XG4gICAgICAgIHt0aXRsZX1cbiAgICAgIDwvSGVhZGluZz5cbiAgICAgIDxUZXh0IHRleHRTdHlsZT1cImluZ3Jlc3NcIiBlbGVtZW50PVwiZGl2XCIgbGFuZz17bGFuZ30+XG4gICAgICAgIHtpbnRyb2R1Y3Rpb259XG4gICAgICA8L1RleHQ+XG4gICAgICB7Y29udGVudH1cbiAgICAgIDxBcnRpY2xlQnlsaW5lIGxpY2Vuc2VCb3g9e2xpY2Vuc2VCb3h9IGRpc3BsYXlCeWxpbmU9e2ZhbHNlfSAvPlxuICAgIDwvU3R5bGVkQXJ0aWNsZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEZyb250cGFnZUFydGljbGU7XG4iXX0= */"));
29
29
  const FrontpageArticle = _ref => {
30
30
  let {
31
31
  article,
@@ -69,7 +69,6 @@ const FrontpageArticle = _ref => {
69
69
  lang: lang,
70
70
  children: introduction
71
71
  }), content, (0, _jsxRuntime.jsx)(_Article.ArticleByline, {
72
- accordionHeaderVariant: "white",
73
72
  licenseBox: licenseBox,
74
73
  displayByline: false
75
74
  })]
package/lib/index.d.ts CHANGED
@@ -24,7 +24,6 @@ export { default as SearchResultSleeve } from "./Search/SearchResultSleeve";
24
24
  export { default as ContentTypeResult } from "./Search/ContentTypeResult";
25
25
  export { SearchFieldForm } from "./Search/SearchFieldForm";
26
26
  export { default as resourceTypeColor } from "./utils/resourceTypeColor";
27
- export { default as CreatedBy } from "./CreatedBy";
28
27
  export { MessageBox, MessageBanner } from "./Messages";
29
28
  export { ResourceBox } from "./ResourceBox";
30
29
  export { default as AudioPlayer } from "./AudioPlayer";
package/lib/index.js CHANGED
@@ -207,12 +207,6 @@ Object.defineProperty(exports, "CopyrightEmbed", {
207
207
  return _Embed.CopyrightEmbed;
208
208
  }
209
209
  });
210
- Object.defineProperty(exports, "CreatedBy", {
211
- enumerable: true,
212
- get: function () {
213
- return _CreatedBy.default;
214
- }
215
- });
216
210
  Object.defineProperty(exports, "DefaultSnackbar", {
217
211
  enumerable: true,
218
212
  get: function () {
@@ -758,7 +752,6 @@ var _SearchResultSleeve = _interopRequireDefault(require("./Search/SearchResultS
758
752
  var _ContentTypeResult = _interopRequireDefault(require("./Search/ContentTypeResult"));
759
753
  var _SearchFieldForm = require("./Search/SearchFieldForm");
760
754
  var _resourceTypeColor = _interopRequireDefault(require("./utils/resourceTypeColor"));
761
- var _CreatedBy = _interopRequireDefault(require("./CreatedBy"));
762
755
  var _Messages = require("./Messages");
763
756
  var _ResourceBox = require("./ResourceBox");
764
757
  var _AudioPlayer = _interopRequireDefault(require("./AudioPlayer"));
@@ -19,6 +19,7 @@ export declare const MISSING = "missing";
19
19
  export declare const IMAGE = "image";
20
20
  export declare const VIDEO = "video";
21
21
  export declare const AUDIO = "audio";
22
+ export declare const PODCAST = "podcast";
22
23
  export declare const contentTypes: {
23
24
  SUBJECT_MATERIAL: string;
24
25
  TASKS_AND_ACTIVITIES: string;
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.resourceEmbedTypeMapping = exports.contentTypes = exports.contentTypeMapping = exports.VIDEO = exports.TOPIC = exports.TASKS_AND_ACTIVITIES = exports.SUBJECT_MATERIAL = exports.SUBJECT = exports.SOURCE_MATERIAL = exports.RESOURCE_TYPE_TASKS_AND_ACTIVITIES = exports.RESOURCE_TYPE_SUBJECT_MATERIAL = exports.RESOURCE_TYPE_SOURCE_MATERIAL = exports.RESOURCE_TYPE_LEARNING_PATH = exports.RESOURCE_TYPE_CONCEPT = exports.RESOURCE_TYPE_ASSESSMENT_RESOURCES = exports.MULTIDISCIPLINARY_TOPIC = exports.MISSING = exports.ListOfContentTypes = exports.LEARNING_PATH = exports.IMAGE = exports.EXTERNAL = exports.CONCEPT = exports.AUDIO = exports.ASSESSMENT_RESOURCES = void 0;
6
+ exports.resourceEmbedTypeMapping = exports.contentTypes = exports.contentTypeMapping = exports.VIDEO = exports.TOPIC = exports.TASKS_AND_ACTIVITIES = exports.SUBJECT_MATERIAL = exports.SUBJECT = exports.SOURCE_MATERIAL = exports.RESOURCE_TYPE_TASKS_AND_ACTIVITIES = exports.RESOURCE_TYPE_SUBJECT_MATERIAL = exports.RESOURCE_TYPE_SOURCE_MATERIAL = exports.RESOURCE_TYPE_LEARNING_PATH = exports.RESOURCE_TYPE_CONCEPT = exports.RESOURCE_TYPE_ASSESSMENT_RESOURCES = exports.PODCAST = exports.MULTIDISCIPLINARY_TOPIC = exports.MISSING = exports.ListOfContentTypes = exports.LEARNING_PATH = exports.IMAGE = exports.EXTERNAL = exports.CONCEPT = exports.AUDIO = exports.ASSESSMENT_RESOURCES = void 0;
7
7
  /**
8
8
  * Copyright (c) 2017-present, NDLA.
9
9
  *
@@ -26,6 +26,7 @@ const MISSING = exports.MISSING = "missing";
26
26
  const IMAGE = exports.IMAGE = "image";
27
27
  const VIDEO = exports.VIDEO = "video";
28
28
  const AUDIO = exports.AUDIO = "audio";
29
+ const PODCAST = exports.PODCAST = "podcast";
29
30
  const contentTypes = exports.contentTypes = {
30
31
  SUBJECT_MATERIAL,
31
32
  TASKS_AND_ACTIVITIES,
@@ -59,5 +60,6 @@ const resourceEmbedTypeMapping = exports.resourceEmbedTypeMapping = {
59
60
  image: "image",
60
61
  video: "video",
61
62
  concept: "concept",
62
- audio: "audio"
63
+ audio: "audio",
64
+ podcast: "podcast"
63
65
  };