forked from VigoTech/vigotech.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nuxt.config.js
116 lines (109 loc) · 2.5 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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
const pkg = require('./package');
require('dotenv').config();
const markdown = require('./markdown');
const markdownFiles = markdown.getFiles();
const routerBase =
process.env.DEPLOY_ENV === 'GH_PAGES'
? {
router: {
base: '/',
baseUrl: process.env.BASE_URL
}
}
: {
router: {
base: '/'
}
};
module.exports = {
...routerBase,
mode: 'universal',
env: { ...process.env },
/*
** Headers of the page
*/
head: {
title: process.env.HEAD_TITLE,
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ hid: 'description', name: 'description', content: pkg.description }
],
link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon.png' }],
bodyAttrs: {
class: 'layout'
}
},
/*
** Customize the progress-bar color
*/
loading: { color: '#e84a5f' },
/*
** Global CSS
*/
css: [
process.env.MAIN_SCSS_FILE,
'font-awesome/css/font-awesome.css',
'flexboxgrid/css/flexboxgrid.css',
'video.js/dist/video-js.css'
],
/*
** Plugins to load before mounting the App
*/
plugins: [
{ src: '~/plugins/scrollTo.js', ssr: false },
{ src: '~/plugins/scrollactive.js', ssr: false },
{ src: '~/plugins/sticky.js', ssr: false },
{ src: '~/plugins/moment.js' },
{ src: '~/plugins/localStorage.js', ssr: false },
{ src: '~/plugins/nuxt-video-player-plugin.js', ssr: false },
{ src: '~/plugins/cookies.js', ssr: false },
{ src: '~/plugins/ga.js', ssr: false }
],
/*
** Nuxt.js modules
*/
modules: [
'@nuxtjs/dotenv',
'@nuxtjs/axios',
'@nuxtjs/proxy',
['@nuxtjs/markdownit', { linkify: true }]
],
/*
** Generate
*/
generate: {
routes: function() {
const mdRoutes = markdownFiles.map(markdown.getSlugs);
return mdRoutes;
}
},
/*
** Axios module configuration
*/
axios: {
// See https://github.com/nuxt-community/axios-module#options
baseURL: routerBase.router.baseUrl,
browserBaseURL: routerBase.router.baseUrl
},
/*
** Build configuration
*/
build: {
/*
** You can extend webpack config here
*/
extractCSS: true,
extend(config, ctx) {
// Run ESLint on save
if (ctx.isDev && ctx.isClient) {
config.module.rules.push({
enforce: 'pre',
test: /\.(js|vue)$/,
loader: 'eslint-loader',
exclude: /(node_modules)/
});
}
}
}
};