import { useRouter } from 'next/router' import cx from 'classnames' import { Heading } from '@primer/components' import { ZapIcon, InfoIcon, ShieldLockIcon } from '@primer/octicons-react' import { Callout } from 'components/ui/Callout' import { Link } from 'components/Link' import { DefaultLayout } from 'components/DefaultLayout' import { ArticleTitle } from 'components/article/ArticleTitle' import { MiniTocItem, useArticleContext } from 'components/context/ArticleContext' import { useTranslation } from 'components/hooks/useTranslation' import { LearningTrackNav } from './LearningTrackNav' import { MarkdownContent } from 'components/ui/MarkdownContent' import { Lead } from 'components/ui/Lead' import { ArticleGridLayout } from './ArticleGridLayout' // Mapping of a "normal" article to it's interactive counterpart const interactiveAlternatives: Record = { '/actions/automating-builds-and-tests/building-and-testing-nodejs': { href: '/actions/automating-builds-and-tests/building-and-testing-nodejs-or-python?langId=nodejs', }, '/actions/automating-builds-and-tests/building-and-testing-python': { href: '/actions/automating-builds-and-tests/building-and-testing-nodejs-or-python?langId=python', }, } export const ArticlePage = () => { const router = useRouter() const { title, intro, effectiveDate, renderedPage, contributor, permissions, includesPlatformSpecificContent, defaultPlatform, product, miniTocItems, currentLearningTrack, } = useArticleContext() const { t } = useTranslation('pages') const currentPath = router.asPath.split('?')[0] const renderTocItem = (item: MiniTocItem) => { return (
  • {item.items && item.items.length > 0 ? (
      {item.items.map(renderTocItem)}
    ) : null}
  • ) } return (
    {title}} intro={ <> {contributor && (

    {t('contributor_callout')} {contributor.name}.

    )} {intro && ( {intro} )} {permissions && (
    )} {includesPlatformSpecificContent && ( )} {product && ( )} } toc={ <> {!!interactiveAlternatives[currentPath] && (
    Try the new interactive article
    )} {miniTocItems.length > 1 && ( <> {t('miniToc')}
      {miniTocItems.map(renderTocItem)}
    )} } >
    {renderedPage} {effectiveDate && (
    Effective as of:{' '}
    )}
    {currentLearningTrack?.trackName ? (
    ) : null}
    ) }