forked from iaincollins/nextjs-starter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path_error.js
78 lines (71 loc) · 2.21 KB
/
_error.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/**
* Creating a page named _error.js lets you override HTTP error messages
*/
import React from 'react'
import Head from 'next/head'
import Link from 'next/link'
import { Container } from 'reactstrap'
import Styles from '../css/index.scss'
import { withRouter } from 'next/router'
class ErrorPage extends React.Component {
static propTypes() {
return {
errorCode: React.PropTypes.number.isRequired,
url: React.PropTypes.string.isRequired
}
}
static getInitialProps({res, xhr}) {
const errorCode = res ? res.statusCode : (xhr ? xhr.status : null)
return {errorCode}
}
render() {
var response
switch (this.props.errorCode) {
case 200: // Also display a 404 if someone requests /_error explicitly
case 404:
response = (
<div>
<Head>
<style dangerouslySetInnerHTML={{__html: Styles}}/>
</Head>
<Container className="pt-5 text-center">
<h1 className="display-4">Page Not Found</h1>
<p>The page <strong>{ this.props.router.pathname }</strong> does not exist.</p>
<p><Link href="/"><a>Home</a></Link></p>
</Container>
</div>
)
break
case 500:
response = (
<div>
<Head>
<style dangerouslySetInnerHTML={{__html: Styles}}/>
</Head>
<Container className="pt-5 text-center">
<h1 className="display-4">Internal Server Error</h1>
<p>An internal server error occurred.</p>
</Container>
</div>
)
break
default:
response = (
<div>
<Head>
<style dangerouslySetInnerHTML={{__html: Styles}}/>
</Head>
<Container className="pt-5 text-center">
<h1 className="display-4">HTTP { this.props.errorCode } Error</h1>
<p>
An <strong>HTTP { this.props.errorCode }</strong> error occurred while
trying to access <strong>{ this.props.router.pathname }</strong>
</p>
</Container>
</div>
)
}
return response
}
}
export default withRouter(ErrorPage)