mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-27 13:52:38 +00:00
consitent production error pages
This commit is contained in:
parent
8b63b64f54
commit
d9c2c85f2a
@ -1,11 +1,26 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="error-page">
|
<div class="__nuxt-error-page">
|
||||||
<div>
|
<div class="container">
|
||||||
<h1 class="error-code">{{ error.statusCode }}</h1>
|
|
||||||
<div class="error-wrapper-message">
|
<div class="row">
|
||||||
<h2 class="error-message">{{ error.message }}</h2>
|
<div class="column">
|
||||||
</div>
|
<h1>{{ error.statusCode }} </h1>
|
||||||
<p v-if="error.statusCode === 404"><nuxt-link class="error-link" to="/">Back to the home page</nuxt-link></p>
|
<h4> {{ $route.path }} </h4>
|
||||||
|
<pre class="error-box"><code>{{ error.message }}</code></pre>
|
||||||
|
<p v-if="error.statusCode === 404">
|
||||||
|
<nuxt-link class="error-link" to="/">Back to the home page</nuxt-link>
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="column">
|
||||||
|
<div class="poweredby">
|
||||||
|
<small> Powered by <a href="https://nuxtjs.org">Nuxt.js</a> </small>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -16,51 +31,40 @@ export default {
|
|||||||
props: ['error'],
|
props: ['error'],
|
||||||
head () {
|
head () {
|
||||||
return {
|
return {
|
||||||
title: this.error.message || 'An error occured'
|
title: this.error ? ((this.error.statusCode || 500) + ' - ' + (this.error.message || 'Error')) : '500 - Error',
|
||||||
|
link: [
|
||||||
|
{ rel: 'stylesheet', href: 'https://cdnjs.cloudflare.com/ajax/libs/normalize/7.0.0/normalize.min.css', type: 'text/css', media: 'all' },
|
||||||
|
{ rel: 'stylesheet', href: 'https://cdnjs.cloudflare.com/ajax/libs/milligram/1.3.0/milligram.min.css', type: 'text/css', media: 'all' }
|
||||||
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style>
|
||||||
.error-page {
|
.__nuxt-error-page {
|
||||||
color: #000;
|
background: #edecea;
|
||||||
background: #fff;
|
font-size: 1em;
|
||||||
top: 0;
|
word-spacing: 1px;
|
||||||
bottom: 0;
|
-ms-text-size-adjust: 100%;
|
||||||
left: 0;
|
-webkit-text-size-adjust: 100%;
|
||||||
right: 0;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
position: absolute;
|
-webkit-font-smoothing: antialiased;
|
||||||
font-family: "SF UI Text", "Helvetica Neue", "Lucida Grande";
|
}
|
||||||
|
.__nuxt-error-page .container {
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
align-items: center;
|
||||||
|
flex-direction: column;
|
||||||
|
width: 100vw;
|
||||||
|
height: 100vh;
|
||||||
|
}
|
||||||
|
.__nuxt-error-page .error-box {
|
||||||
|
box-shadow: 0px 0px 9px #d3d3d3;
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
.__nuxt-error-page .poweredby {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
padding-top: 20%;
|
margin-top: 10%;
|
||||||
}
|
|
||||||
.error-code {
|
|
||||||
display: inline-block;
|
|
||||||
font-size: 24px;
|
|
||||||
font-weight: 500;
|
|
||||||
vertical-align: top;
|
|
||||||
border-right: 1px solid rgba(0, 0, 0, 0.298039);
|
|
||||||
margin: 0px 20px 0px 0px;
|
|
||||||
padding: 10px 23px;
|
|
||||||
}
|
|
||||||
.error-wrapper-message {
|
|
||||||
display: inline-block;
|
|
||||||
text-align: left;
|
|
||||||
line-height: 49px;
|
|
||||||
height: 49px;
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
.error-message {
|
|
||||||
font-size: 14px;
|
|
||||||
font-weight: normal;
|
|
||||||
margin: 0px;
|
|
||||||
padding: 0px;
|
|
||||||
}
|
|
||||||
.error-link {
|
|
||||||
color: #00BCD4;
|
|
||||||
font-weight: normal;
|
|
||||||
text-decoration: none;
|
|
||||||
font-size: 14px;
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
File diff suppressed because one or more lines are too long
@ -56,12 +56,6 @@ export default class Renderer extends Tapable {
|
|||||||
// Setup nuxt middleware
|
// Setup nuxt middleware
|
||||||
await this.setupMiddleware()
|
await this.setupMiddleware()
|
||||||
|
|
||||||
// Load error template for when debug is disabled
|
|
||||||
const errorTemplatePath = resolve(this.options.buildDir, 'views/error.html')
|
|
||||||
if (fs.existsSync(errorTemplatePath)) {
|
|
||||||
this.resources.errorTemplate = parseTemplate(fs.readFileSync(errorTemplatePath, 'utf8'))
|
|
||||||
}
|
|
||||||
|
|
||||||
// Load SSR resources from fs
|
// Load SSR resources from fs
|
||||||
if (!this.options.dev) {
|
if (!this.options.dev) {
|
||||||
await this.loadResources()
|
await this.loadResources()
|
||||||
@ -96,6 +90,13 @@ export default class Renderer extends Tapable {
|
|||||||
this.resources[key] = data
|
this.resources[key] = data
|
||||||
updated.push(key)
|
updated.push(key)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// Reload error template
|
||||||
|
const errorTemplatePath = resolve(this.options.buildDir, 'views/error.html')
|
||||||
|
if (fs.existsSync(errorTemplatePath)) {
|
||||||
|
this.resources.errorTemplate = parseTemplate(fs.readFileSync(errorTemplatePath, 'utf8'))
|
||||||
|
}
|
||||||
|
|
||||||
if (updated.length > 0) {
|
if (updated.length > 0) {
|
||||||
// debug('Updated', updated.join(', '), isServer)
|
// debug('Updated', updated.join(', '), isServer)
|
||||||
this.createRenderer()
|
this.createRenderer()
|
||||||
@ -419,7 +420,7 @@ export default class Renderer extends Tapable {
|
|||||||
HTML_ATTRS: '',
|
HTML_ATTRS: '',
|
||||||
BODY_ATTRS: '',
|
BODY_ATTRS: '',
|
||||||
HEAD: '',
|
HEAD: '',
|
||||||
APP: <div id="__nuxt"></div>
|
APP: '<div id="__nuxt"></div>'
|
||||||
}
|
}
|
||||||
|
|
||||||
if (SPAData) {
|
if (SPAData) {
|
||||||
|
Loading…
Reference in New Issue
Block a user