-
Notifications
You must be signed in to change notification settings - Fork 0
/
gridsome.server.js
35 lines (29 loc) · 1.25 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
// 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`
module.exports = function (api) {
api.loadSource(({ addContentType }) => {
// Use the Data Store API here: https://gridsome.org/docs/data-store-api
})
api.createPages(({ createPage }) => {
// Use the Pages API here: https://gridsome.org/docs/pages-api
})
}
function useProcessedImages (api, options) {
const fs = require('fs-extra')
const { info } = require('gridsome/lib/utils/log')
api.afterBuild(() => {
info(`After build... copy ${api.config.imagesDir} to ./${options.processedImagesDir}`)
fs.copySync(api.config.imagesDir, './' + options.processedImagesDir)
})
api.beforeBuild(() => {
info(`Before build... move ./${options.processedImagesDir} to: ${api.config.imageCacheDir}`)
fs.moveSync('./' + options.processedImagesDir, api.config.imageCacheDir, { overwrite: true })
})
}
useProcessedImages.defaultOptions = () => ({
processedImagesDir: 'pimages' // Relative to project root
})
module.exports = useProcessedImages