@ndla/ui 46.0.0 → 46.0.2

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.
@@ -33,17 +33,17 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } /**
33
33
  var Wrapper = /*#__PURE__*/(0, _base.default)("div", {
34
34
  target: "eeu23se5",
35
35
  label: "Wrapper"
36
- })("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":"AAmB0B","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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
+ })("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":"AAmB0B","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
37
37
  var TextWrapper = /*#__PURE__*/(0, _base.default)("div", {
38
38
  target: "eeu23se4",
39
39
  label: "TextWrapper"
40
40
  })("display:flex;justify-content:space-between;width:100%;padding-bottom:", _core.spacing.mediumlarge, ";", _core.mq.range({
41
41
  until: _core.breakpoints.tabletWide
42
- }), "{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":"AA6B8B","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
42
+ }), "{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":"AA6B8B","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
43
43
  var PrimaryContributorsWrapper = /*#__PURE__*/(0, _base.default)("span", {
44
44
  target: "eeu23se3",
45
45
  label: "PrimaryContributorsWrapper"
46
- })("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":"AAyC8C","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
46
+ })("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":"AAyC8C","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
47
47
  var renderContributors = function renderContributors(contributors, t) {
48
48
  var contributorsArray = contributors.map(function (contributor, index) {
49
49
  if (index < 1) return contributor.name;
@@ -71,15 +71,15 @@ var getSuppliersText = function getSuppliersText(suppliers, t) {
71
71
  var LicenseWrapper = /*#__PURE__*/(0, _base.default)("div", {
72
72
  target: "eeu23se2",
73
73
  label: "LicenseWrapper"
74
- })("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":"AAuFiC","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
74
+ })("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":"AAwFiC","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
75
75
  var StyledAccordionHeader = /*#__PURE__*/(0, _base.default)(_accordion.AccordionHeader, {
76
76
  target: "eeu23se1",
77
77
  label: "StyledAccordionHeader"
78
- })("background-color:", _core.colors.brand.lightest, ";font-size:", _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":"AA6FqD","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
78
+ })("background-color:", _core.colors.brand.lightest, ";font-size:", _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":"AA8FqD","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
79
79
  var StyledAccordionContent = /*#__PURE__*/(0, _base.default)(_accordion.AccordionContent, {
80
80
  target: "eeu23se0",
81
81
  label: "StyledAccordionContent"
82
- })("&[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":"AAuGuD","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    window.addEventListener('hashchange', onHashChange);\n    return () => window.removeEventListener('hashchange', onHashChange);\n  }, [onHashChange]);\n\n  const license = getLicenseByAbbreviation(licenseString, locale);\n\n  const showPrimaryContributors = suppliers.length > 0 || authors.length > 0;\n\n  return (\n    <Wrapper>\n      <TextWrapper>\n        <LicenseWrapper>\n          <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('article.lastUpdated')} {published}\n        </div>\n      </TextWrapper>\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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"]} */"));
82
+ })("&[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":"AAwGuD","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 { ReactNode, useCallback, useEffect, useState } from 'react';\nimport styled from '@emotion/styled';\nimport { breakpoints, colors, fonts, mq, spacing } from '@ndla/core';\nimport { useTranslation } from 'react-i18next';\nimport { getLicenseByAbbreviation } from '@ndla/licenses';\nimport { AccordionRoot, AccordionHeader, AccordionContent, AccordionItem } from '@ndla/accordion';\nimport { TFunction } from 'i18next';\nimport { FootNote } from '../types';\nimport ArticleFootNotes from './ArticleFootNotes';\nimport LicenseLink from '../LicenseByline/LicenseLink';\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`;\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};\n\nconst renderContributors = (contributors: SupplierProps[] | AuthorProps[], t: TFunction) => {\n  const contributorsArray = contributors.map((contributor, index) => {\n    if (index < 1) return contributor.name;\n    const sep = index === contributors.length - 1 ? ` ${t('article.conjunction')} ` : ', ';\n    return `${sep}${contributor.name}`;\n  });\n  return contributorsArray.join('');\n};\n\nconst getSuppliersText = (suppliers: SupplierProps[], t: TFunction) => {\n  if (suppliers.length === 0) {\n    return '';\n  }\n  return suppliers.length > 1\n    ? t('article.multipleSuppliersLabel', {\n        names: renderContributors(suppliers, t),\n        interpolation: { escapeValue: false },\n      })\n    : t('article.supplierLabel', { name: renderContributors(suppliers, t), interpolation: { escapeValue: false } });\n};\n\nconst 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  font-size: ${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}: Props) => {\n  const { t } = useTranslation();\n  const [openAccordions, setOpenAccordions] = useState<string[]>([]);\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    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>\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('article.lastUpdated')} {published}\n          </div>\n        </TextWrapper>\n      )}\n      <AccordionRoot type=\"multiple\" onValueChange={setOpenAccordions} value={openAccordions}>\n        {licenseBox && (\n          <AccordionItem value=\"rulesForUse\">\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
83
  var refRegexp = /note\d/;
84
84
  var footnotesAccordionId = 'footnotes';
85
85
  var ArticleByline = function ArticleByline(_ref) {
@@ -93,7 +93,9 @@ var ArticleByline = function ArticleByline(_ref) {
93
93
  published = _ref.published,
94
94
  locale = _ref.locale,
95
95
  _ref$accordionHeaderV = _ref.accordionHeaderVariant,
96
- accordionHeaderVariant = _ref$accordionHeaderV === void 0 ? 'blue' : _ref$accordionHeaderV;
96
+ accordionHeaderVariant = _ref$accordionHeaderV === void 0 ? 'blue' : _ref$accordionHeaderV,
97
+ _ref$displayByline = _ref.displayByline,
98
+ displayByline = _ref$displayByline === void 0 ? true : _ref$displayByline;
97
99
  var _useTranslation = (0, _reactI18next.useTranslation)(),
98
100
  t = _useTranslation.t;
99
101
  var _useState = (0, _react.useState)([]),
@@ -115,12 +117,12 @@ var ArticleByline = function ArticleByline(_ref) {
115
117
  return window.removeEventListener('hashchange', onHashChange);
116
118
  };
117
119
  }, [onHashChange]);
118
- var license = (0, _licenses.getLicenseByAbbreviation)(licenseString, locale);
120
+ var license = licenseString && (0, _licenses.getLicenseByAbbreviation)(licenseString, locale);
119
121
  var showPrimaryContributors = suppliers.length > 0 || authors.length > 0;
120
122
  return (0, _jsxRuntime.jsxs)(Wrapper, {
121
- children: [(0, _jsxRuntime.jsxs)(TextWrapper, {
123
+ children: [displayByline && (0, _jsxRuntime.jsxs)(TextWrapper, {
122
124
  children: [(0, _jsxRuntime.jsxs)(LicenseWrapper, {
123
- children: [(0, _jsxRuntime.jsx)(_LicenseLink.default, {
125
+ children: [license && (0, _jsxRuntime.jsx)(_LicenseLink.default, {
124
126
  license: license
125
127
  }), showPrimaryContributors && (0, _jsxRuntime.jsxs)(PrimaryContributorsWrapper, {
126
128
  children: [authors.length > 0 && "".concat(t('article.authorsLabel', {