forked from contentful/blog-in-5-minutes
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nuxt.config.js
114 lines (106 loc) · 2.83 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
const {getConfigForKeys} = require('./lib/config.js')
const ctfConfig = getConfigForKeys([
'CTF_BLOG_POST_TYPE_ID',
'CTF_SPACE_ID',
'CTF_CDA_ACCESS_TOKEN',
'CTF_CMA_ACCESS_TOKEN',
'CTF_PERSON_ID'
])
const {createClient} = require('./plugins/contentful')
const cdaClient = createClient(ctfConfig)
const cmaContentful = require('contentful-management')
const cmaClient = cmaContentful.createClient({
accessToken: ctfConfig.CTF_CMA_ACCESS_TOKEN
})
const config = {
/*
** Headers of the page
*/
head: {
title: 'Custom app with Contentful',
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ hid: 'description', name: 'description', content: 'Custom app in under 5 minutes' }
],
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon.png' },
{ rel: 'stylesheet', href: 'https://cdnjs.cloudflare.com/ajax/libs/minireset.css/0.0.2/minireset.min.css' }
]
},
/*
** Customize the progress-bar color
*/
loading: { color: '#2199e8' },
/*
** Build configuration
*/
build: {
/*
** Run ESLINT on save
*/
extend (config, ctx) {
if (ctx.isClient) {
config.module.rules.push({
enforce: 'pre',
test: /\.(js|vue)$/,
loader: 'eslint-loader',
exclude: /(node_modules)/
})
}
},
postcss: [
require('autoprefixer')({
browsers: ['> 5%']
})
]
},
/*
** ᕕ( ᐛ )ᕗ CTF-BLOG-IN-5-MINUTES
** Make client available everywhere via Nuxt plugins
*/
plugins: [
'~/plugins/contentful'
],
/*
** ᕕ( ᐛ )ᕗ CTF-BLOG-IN-5-MINUTES
** Get all blog posts from Contentful
** and generate the needed files upfront
**
** Included:
** - blog posts
** - available blog post tags
*/
generate: {
routes () {
return Promise.all([
// get all blog posts
cdaClient.getEntries({
'content_type': ctfConfig.CTF_BLOG_POST_TYPE_ID
}),
// get the blog post content type
cmaClient.getSpace(ctfConfig.CTF_SPACE_ID)
.then(space => space.getContentType(ctfConfig.CTF_BLOG_POST_TYPE_ID))
])
.then(([entries, postType]) => {
return [
// map entries to URLs
...entries.items.map(entry => `/blog/${entry.fields.slug}`),
// map all possible tags to URLs
...postType.fields.find(field => field.id === 'tags').items.validations[0].in.map(tag => `/tags/${tag}`)
]
})
}
},
/*
** Define environment variables being available
** in generate and browser context
*/
env: {
CTF_SPACE_ID: ctfConfig.CTF_SPACE_ID,
CTF_CDA_ACCESS_TOKEN: ctfConfig.CTF_CDA_ACCESS_TOKEN,
CTF_PERSON_ID: ctfConfig.CTF_PERSON_ID,
CTF_BLOG_POST_TYPE_ID: ctfConfig.CTF_BLOG_POST_TYPE_ID
}
}
module.exports = config