-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgridsome.server.js
45 lines (36 loc) · 1.38 KB
/
gridsome.server.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
// Server API makes it possible to hook into various parts of Gridsome
// on server-side and add custom data to the GraphQL data layer.
// Learn more: https://gridsome.org/docs/server-api
// Changes here require a server restart.
// To restart press CTRL + C in terminal and run `gridsome develop`
const fs = require('fs');
const path = require('path');
const pick = require('lodash.pick');
module.exports = function (api, options) {
api.loadSource(store => {
// Use the Data store API here: https://gridsome.org/docs/data-store-api
})
api.beforeBuild(({ config, store }) => {
// Generate an index file for Fuse to search Posts
const { collection } = store.getContentType('Post');
const posts = collection.data.map(post => {
return pick(post, ['title', 'path', 'summary']);
});
const output = {
dir: './static',
name: 'search.json',
...options.output
}
const outputPath = path.resolve(process.cwd(), output.dir)
const outputPathExists = fs.existsSync(outputPath)
const fileName = output.name.endsWith('.json')
? output.name
: `${output.name}.json`
if (outputPathExists) {
fs.writeFileSync(path.resolve(process.cwd(), output.dir, fileName), JSON.stringify(posts))
} else {
fs.mkdirSync(outputPath)
fs.writeFileSync(path.resolve(process.cwd(), output.dir, fileName), JSON.stringify(posts))
}
})
}