-
Notifications
You must be signed in to change notification settings - Fork 0
/
gridsome.server.js
49 lines (44 loc) · 1.31 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
46
47
48
49
// 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 { pathPrefix } = require("./gridsome.config")
module.exports = function(api, options) {
api.loadSource(store => {
/*
Clean the pathPrefix
====================
not used => '/'
'' => '/'
'/' => '/'
'/path' => '/path'
'path' => '/path'
'path/' => '/path'
'/path/' => '/path'
*/
const cleanedPathPrefix = `${
pathPrefix
? ["", ...pathPrefix.split("/").filter(dir => dir.length)].join("/")
: ""
}`
/*
Query
=====
<static-query> <!-- or a page-query -->
{
metaData{
pathPrefix
}
}
</static-query>
Requests for static files should look like this:
===============================================
Using static-queries: axios( this.$static.metaData.pathPrefix + "/fileName" )
Using page-queries, axios( this.$page.metaData.pathPrefix + "/fileName" )
*/
store.addMetadata("pathPrefix", cleanedPathPrefix)
})
}