Roadmap to becoming a developer in 2022
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

86 lines
2.1 KiB

import { Box, Container } from '@chakra-ui/react';
import { GlobalHeader } from '../../components/global-header';
import { OpensourceBanner } from '../../components/opensource-banner';
import { Footer } from '../../components/footer';
import { ContentPageHeader } from '../../components/content-page-header';
import MdRenderer from '../../components/md-renderer';
import { getAllGuides, getGuideById, GuideType } from '../../lib/guide';
import siteConfig from '../../content/site.json';
import Helmet from '../../components/helmet';
type GuideProps = {
guide: GuideType;
};
export default function Guide(props: GuideProps) {
const { guide } = props;
const GuideContent = require(`../../content/guides/${guide.id}.md`).default;
return (
<Box bg='white' minH='100vh'>
<GlobalHeader />
<Helmet
title={guide.title}
description={guide.description}
/>
<Box mb='60px'>
<ContentPageHeader
title={guide.title}
subtitle={guide.description}
formattedDate={guide.formattedUpdatedAt!}
author={{
twitter: guide?.author?.twitter!,
picture: guide?.author?.picture!,
name: guide?.author?.name!
}}
subLink={{
text: 'Improve this Guide',
url: `${siteConfig.url.repo}/tree/master/content/guides/${guide.id}.md`
}}
/>
<Container maxW={'container.md'} position='relative'>
<MdRenderer>
<GuideContent />
</MdRenderer>
</Container>
</Box>
<OpensourceBanner />
<Footer />
</Box>
);
}
type StaticPathItem = {
params: {
guide: string
}
};
export async function getStaticPaths() {
const guides = getAllGuides();
const paramsList: StaticPathItem[] = guides.map(guide => ({
params: { 'guide': guide.id }
}));
return {
paths: paramsList,
fallback: false
};
}
type ContextType = {
params: {
guide: string
}
};
export async function getStaticProps(context: ContextType) {
const guideId: string = context?.params?.guide;
return {
props: {
guide: getGuideById(guideId)
}
};
}