import { useRouter } from 'next/router' import dynamic from 'next/dynamic' import { ZapIcon, InfoIcon } 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 { 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' import { PlatformPicker } from 'components/article/PlatformPicker' import { ToolPicker } from 'components/article/ToolPicker' import { MiniTocs } from 'components/ui/MiniTocs' import { ClientSideHighlight } from 'components/ClientSideHighlight' const ClientSideRefresh = dynamic(() => import('components/ClientSideRefresh'), { ssr: false, }) const isDev = process.env.NODE_ENV === 'development' // Mapping of a "normal" article to it's interactive counterpart const interactiveAlternatives: Record = { '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-nodejs-project-for-codespaces': { href: '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-project-for-codespaces?langId=nodejs', }, '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-dotnet-project-for-codespaces': { href: '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-project-for-codespaces?langId=dotnet', }, '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-java-project-for-codespaces': { href: '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-project-for-codespaces?langId=java', }, '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-python-project-for-codespaces': { href: '/codespaces/setting-up-your-project-for-codespaces/setting-up-your-project-for-codespaces?langId=py', }, } export const ArticlePage = () => { const { asPath } = useRouter() const { title, intro, effectiveDate, renderedPage, contributor, permissions, includesPlatformSpecificContent, includesToolSpecificContent, product, miniTocItems, currentLearningTrack, } = useArticleContext() const { t } = useTranslation('pages') const currentPath = asPath.split('?')[0] return ( {isDev && }
{title}} intro={ <> {contributor && (

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

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