-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnuxt.config.js
92 lines (84 loc) · 2.87 KB
/
nuxt.config.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
const routerBase = process.env.DEPLOY_ENV === 'GH_PAGES'
? {
router: {
base: '/'
}
} : {}
export default {
target: 'static',
// Global page headers (https://go.nuxtjs.dev/config-head)
head: {
title: 'Steven Yu',
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ hid: 'description', name: 'description', content: '' },
],
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' },
// font-family: 'Courgette', cursive;
{ rel: 'stylesheet', href: 'https://fonts.googleapis.com/css2?family=Courgette&display=swap' },
// font-family: 'Spectral', serif;
{ rel: 'stylesheet', href: 'https://fonts.googleapis.com/css2?family=Spectral:wght@300;400;600;700&display=swap'},
// font-family: 'Mulish', sans-serif;
{ rel: 'stylesheet', href: 'https://fonts.googleapis.com/css2?family=Mulish:wght@400;600;700;800&display=swap' },
// font-family: 'Grandstander', cursive;
{ rel: 'stylesheet', href: 'https://fonts.googleapis.com/css2?family=Grandstander:wght@700;800;900&display=swap' }
],
},
// Global CSS (https://go.nuxtjs.dev/config-css)
css: [],
// Plugins to run before rendering page (https://go.nuxtjs.dev/config-plugins)
plugins: [
{
src: '~plugins/vue-particles',
ssr: false
}
],
// Auto import components (https://go.nuxtjs.dev/config-components)
components: true,
// Modules for dev and build (recommended) (https://go.nuxtjs.dev/config-modules)
buildModules: [
// https://go.nuxtjs.dev/eslint
'@nuxtjs/eslint-module',
],
// Modules (https://go.nuxtjs.dev/config-modules)
modules: [
// https://go.nuxtjs.dev/chakra
'@chakra-ui/nuxt',
// https://go.nuxtjs.dev/emotion
'@nuxtjs/emotion',
// https://go.nuxtjs.dev/axios
'@nuxtjs/axios',
// https://go.nuxtjs.dev/pwa
'@nuxtjs/pwa',
],
// Axios module configuration (https://go.nuxtjs.dev/config-axios)
axios: {},
// Build Configuration (https://go.nuxtjs.dev/config-build)
build: {},
// Optimize images
optimizedImages: {
inlineImageLimit: 1000,
imagesName: ({ isDev }) => isDev ? '[path][name][hash:optimized].[ext]' : 'img/[contenthash:7].[ext]',
responsiveImagesName: ({ isDev }) => isDev ? '[path][name]--[width][hash:optimized].[ext]' : 'img/[contenthash:7]-[width].[ext]',
handleImages: ['jpeg', 'png', 'svg', 'gif'],
optimizeImages: true,
optimizeImagesInDev: false,
defaultImageLoader: 'img-loader',
mozjpeg: {
quality: 80
},
optipng: {
optimizationLevel: 3
},
pngquant: {
speed: 7
},
gifscile: {
interlaced: true,
optimizationLevel: 1
}
},
...routerBase
}