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?.type?.charAt(0).toUpperCase()}${guide?.type?.slice(1)} Guide`}
          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)
    }
  };
}