-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathnuxt.config.js
83 lines (81 loc) · 2.42 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
import axios from 'axios';
import environment from './environment';
export default {
mode: 'universal',
env: environment,
modules: [
'@nuxtjs/style-resources',
['bootstrap-vue/nuxt', { css: false }],
'@nuxtjs/markdownit',
'@nuxtjs/axios'
],
plugins: [
{ src: '~/plugins/nuxt-client-init.js', ssr: false },
{ src: '~/plugins/vue2-google-maps.js' }
],
/* Axios configuration */
axios: {
proxyHeaders: false,
credentials: false
},
/* Headers of the page */
head: {
titleTemplate: `%s - ${process.env.websiteName}`,
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ hid: 'description', name: 'description', content: 'WIP' }
],
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/icons/favicon.ico?v=20190110' },
{ rel: 'stylesheet', href: 'https://use.fontawesome.com/releases/v5.8.1/css/all.css', integrity: 'sha384-50oBUHEmvpQ+1lW4y57PTFmhCaXp0ML5d60M1M7uH2+nqUivzIebhndOJK28anvf', crossorigin: 'anonymous' },
]
},
/* Customize the progress bar color */
loading: { color: '#3B8070' },
/* Load globally required SASS resources. */
styleResources: {
scss: [
'./styles/_variables.scss', // use underscore "_" & also file extension ".scss"
'./styles/_helpers.scss' // use underscore "_" & also file extension ".scss"
]
},
/* Load the main SCSS style */
css: [
'@/styles/main.scss'
],
/* Configuration for generating routes with dynamic params */
generate: {
routes: () => {
const meetupDatesSectionDiscourseEndpoint = 'https://edgeryders.eu/tags/webcontent-culturesquad-event';
return axios.get(`${environment.cacheMiddlewareBaseEndpoint}/get-data?endpoint=${meetupDatesSectionDiscourseEndpoint}`)
.then((res) => {
let events = res.data.topic_list.topics;
return events.map((event) => {
return `/event/${event.slug}/${event.id}`
})
})
}
},
/* Build configuration */
build: {
vendor:[
'babel-polyfill'
],
transpile: ['vue2-google-maps'],
/*
** You can extend webpack config here
*/
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)/
})
}
}
}
};