2022-04-09 17:48:19 -07:00
|
|
|
import styles from "@styles/Home.module.css"
|
|
|
|
import PageSeo from "@components/page-seo"
|
|
|
|
import HomeComponent from "@components/home"
|
|
|
|
import { Page, Text } from "@geist-ui/core"
|
2022-04-19 18:05:21 -07:00
|
|
|
import type { GetStaticProps } from "next"
|
|
|
|
import { InferGetStaticPropsType } from 'next'
|
|
|
|
type Props = {
|
|
|
|
introContent: string
|
|
|
|
introTitle: string
|
|
|
|
rendered: string
|
|
|
|
} | {
|
|
|
|
error: boolean
|
|
|
|
}
|
2022-03-08 16:39:24 -08:00
|
|
|
|
2022-04-19 18:05:21 -07:00
|
|
|
export const getStaticProps: GetStaticProps = async () => {
|
2022-04-09 17:48:19 -07:00
|
|
|
try {
|
|
|
|
const resp = await fetch(process.env.API_URL + `/welcome`, {
|
|
|
|
method: "GET",
|
|
|
|
headers: {
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
"x-secret-key": process.env.SECRET_KEY || ""
|
|
|
|
}
|
|
|
|
})
|
2022-03-24 18:03:57 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const { title, content, rendered } = await resp.json()
|
|
|
|
return {
|
|
|
|
props: {
|
|
|
|
introContent: content || null,
|
|
|
|
rendered: rendered || null,
|
|
|
|
introTitle: title || null
|
2022-04-19 18:05:21 -07:00
|
|
|
},
|
|
|
|
// Next.js will attempt to re-generate the page:
|
|
|
|
// - When a request comes in
|
|
|
|
// - At most every 60 seconds
|
|
|
|
revalidate: 60, // In seconds
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
2022-04-19 18:05:21 -07:00
|
|
|
} catch (err) {
|
|
|
|
// If there was an error, it's likely due to the server not running, so we attempt to regenerate the page
|
2022-04-09 17:48:19 -07:00
|
|
|
return {
|
|
|
|
props: {
|
2022-04-19 18:05:21 -07:00
|
|
|
error: true,
|
|
|
|
},
|
|
|
|
revalidate: 10, // In seconds
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
|
|
|
}
|
2022-03-08 16:39:24 -08:00
|
|
|
}
|
|
|
|
|
2022-04-19 18:05:21 -07:00
|
|
|
// TODO: fix props type
|
|
|
|
const Home = ({ rendered, introContent, introTitle, error }: InferGetStaticPropsType<typeof getStaticProps>) => {
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<Page className={styles.wrapper}>
|
|
|
|
<PageSeo />
|
|
|
|
<Page.Content className={styles.main}>
|
|
|
|
{error && <Text>Something went wrong. Is the server running?</Text>}
|
|
|
|
{!error && (
|
|
|
|
<HomeComponent
|
|
|
|
rendered={rendered}
|
|
|
|
introContent={introContent}
|
|
|
|
introTitle={introTitle}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</Page.Content>
|
|
|
|
</Page>
|
|
|
|
)
|
2022-03-07 16:42:47 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
export default Home
|