index.js 1.2 KB
Newer Older
1 2
import React from 'react'
import Link from 'next/link'
3
import { useRouter } from 'next/router'
4
import 'firebase/firestore'
5

6
export async function getStaticPaths() {
7 8 9 10 11 12 13 14 15
  return {
    paths: [
      '/blog/post-1',
      { params: { post: 'post-2' } },
      '/blog/[post3]',
      '/blog/post-4',
      '/blog/post.1',
      '/blog/post.1', // handle duplicates
    ],
16
    fallback: true,
17
  }
J
JJ Kasper 已提交
18
}
19

20 21
let counter = 0

22
export async function getStaticProps({ params }) {
J
JJ Kasper 已提交
23
  if (params.post === 'post-10') {
J
Joe Haddad 已提交
24
    await new Promise((resolve) => {
J
JJ Kasper 已提交
25 26
      setTimeout(() => resolve(), 1000)
    })
27 28
  }

29 30 31 32
  if (params.post === 'post-100') {
    throw new Error('such broken..')
  }

33 34 35 36 37 38
  if (params.post === 'post-999') {
    if (++counter < 3) {
      throw new Error('try again..')
    }
  }

J
JJ Kasper 已提交
39 40
  return {
    props: {
41
      params,
J
JJ Kasper 已提交
42
      post: params.post,
43
      time: (await import('perf_hooks')).performance.now(),
J
JJ Kasper 已提交
44
    },
T
Tim Neutkens 已提交
45
    revalidate: 10,
46 47
  }
}
J
JJ Kasper 已提交
48

49
export default ({ post, time, params }) => {
J
JJ Kasper 已提交
50 51 52 53
  return (
    <>
      <p>Post: {post}</p>
      <span>time: {time}</span>
54
      <div id="params">{JSON.stringify(params)}</div>
55
      <div id="query">{JSON.stringify(useRouter().query)}</div>
56 57
      <Link href="/">
        <a id="home">to home</a>
J
JJ Kasper 已提交
58 59 60 61
      </Link>
    </>
  )
}