-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathgatsby-config.js
More file actions
296 lines (289 loc) · 9.63 KB
/
gatsby-config.js
File metadata and controls
296 lines (289 loc) · 9.63 KB
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
module.exports = {
flags: {
DEV_SSR: false
},
siteMetadata: {
title: 'OpenInfra Foundation',
description:
'The Home of Open Infrastructure',
url: 'https://openinfra.dev/'
},
plugins: [
'gatsby-plugin-react-helmet',
{
/**
* Gatsby v4 uses ES Modules for importing cssModules by default.
* Disabling this to avoid needing to update in all files and for compatibility
* with other plugins/packages that have not yet been updated.
* @see https://www.gatsbyjs.com/docs/reference/release-notes/migrating-from-v2-to-v3/#css-modules-are-imported-as-es-modules
*
* Also, since libSass was deprecated in October 2020, the Node Sass package has also been deprecated.
* As such, we have migrated from Node Sass to Dart Sass in package.json.
* @see https://www.gatsbyjs.com/plugins/gatsby-plugin-sass/#v300
* @see https://sass-lang.com/blog/libsass-is-deprecated#how-do-i-migrate
*/
resolve: `gatsby-plugin-sass`,
options: {
cssLoaderOptions: {
esModule: false,
modules: {
namedExport: false,
},
},
},
},
{
resolve: "gatsby-plugin-anchor-links",
options: {
offset: 50
}
},
{
resolve: `gatsby-plugin-feed`,
options: {
query: `
{
site {
siteMetadata {
url
site_url: url
}
}
}
`,
feeds: [
{
serialize: ({ query: { site, allMarkdownRemark } }) => {
return allMarkdownRemark.edges.map(edge => {
return Object.assign({}, edge.node.frontmatter, {
description: edge.node.frontmatter.seo.description,
date: edge.node.frontmatter.date,
url: edge.node.frontmatter.seo.url,
guid: edge.node.frontmatter.seo.url,
custom_elements: [{ "content:encoded": edge.node.html }],
})
})
},
query: `
{
allMarkdownRemark(
sort: { order: DESC, fields: [frontmatter___date] },
filter: { frontmatter: { templateKey: { eq: "blog-post" } } }
) {
edges {
node {
html
fields { slug }
frontmatter {
title
date
seo {
description
url
}
}
}
}
}
}
`,
output: "/rss.xml",
title: "OpenInfra Foundation RSS Feed",
// optional configuration to insert feed reference in pages:
// if `string` is used, it will be used to create RegExp and then test if pathname of
// current page satisfied this regular expression;
// if not provided or `undefined`, all pages will have feed reference inserted
match: "^/blog/",
// optional configuration to specify external rss feed, such as feedburner
// link: "https://feeds.feedburner.com/gatsby/blog",
},
],
},
},
{
// keep as first gatsby-source-filesystem plugin for gatsby image support
resolve: 'gatsby-source-filesystem',
options: {
path: `${__dirname}/static/img`,
name: 'uploads',
},
},
{
resolve: 'gatsby-source-filesystem',
options: {
path: `${__dirname}/src/pages`,
name: 'pages',
},
},
{
resolve: 'gatsby-source-filesystem',
options: {
path: `${__dirname}/src/img`,
name: 'images',
},
},
'gatsby-plugin-sharp',
{
resolve: `gatsby-transformer-sharp`,
options: {
checkSupportedExtensions: false,
},
},
{
resolve: 'gatsby-transformer-remark',
options: {
plugins: [
{
resolve: 'gatsby-remark-relative-images',
options: {
name: 'uploads',
},
},
{
resolve: 'gatsby-remark-images',
options: {
// It's important to specify the maxWidth (in pixels) of
// the content container as this plugin uses this as the
// base for generating different widths of each image.
maxWidth: 2048,
linkImagesToOriginal: false,
},
},
{
resolve: 'gatsby-remark-copy-linked-files',
options: {
destinationDir: 'static',
},
},
{
resolve: `gatsby-remark-classes`,
options: {
classMap: {
"heading[depth=3]": "fix-h3",
"heading[depth=2]": "fix-h2",
}
}
},
],
},
},
/**
* This plugin has been deprecated.
* Gatsby now natively supports client paths.
* @see https://www.gatsbyjs.com/plugins/gatsby-plugin-create-client-paths/
* @see https://www.gatsbyjs.com/docs/how-to/routing/client-only-routes-and-user-authentication/#handling-client-only-routes-with-gatsby
*/
// {
// resolve: `gatsby-plugin-create-client-paths`,
// options: { prefixes: [`/auth/*`, `/a/*`, `/members/profile/*`] },
// },
{
resolve: "gatsby-plugin-google-tagmanager",
options: {
id: "GTM-5SLZBPV",
// Include GTM in development.
//
// Defaults to false meaning GTM will only be loaded in production.
includeInDevelopment: true,
// datalayer to be set before GTM is loaded
// should be an object or a function that is executed in the browser
//
// Defaults to null
defaultDataLayer: { platform: "gatsby" },
// Specify optional GTM environment details.
// gtmAuth: "YOUR_GOOGLE_TAGMANAGER_ENVIRONMENT_AUTH_STRING",
// gtmPreview: "YOUR_GOOGLE_TAGMANAGER_ENVIRONMENT_PREVIEW_NAME",
// dataLayerName: "YOUR_DATA_LAYER_NAME",
// Name of the event that is triggered
// on every Gatsby route change.
//
// Defaults to gatsby-route-change
// routeChangeEventName: "YOUR_ROUTE_CHANGE_EVENT_NAME",
// Defaults to false
enableWebVitalsTracking: true,
// Defaults to https://www.googletagmanager.com
// selfHostedOrigin: "YOUR_SELF_HOSTED_ORIGIN",
},
},
{
resolve: `gatsby-plugin-google-gtag`,
options: {
// You can add multiple tracking ids and a pageview event will be fired for all of them.
trackingIds: [
"UA-139234657-1", // Google Analytics / GA,
],
// This object gets passed directly to the gtag config command
// This config will be shared across all trackingIds
gtagConfig: {
anonymize_ip: true,
cookie_expires: 0,
},
// This object is used for configuration specific to this plugin
pluginConfig: {
// Puts tracking script in the head instead of the body
head: true,
// Setting this parameter is also optional
respectDNT: true,
// Avoids sending pageview hits from custom paths
// exclude: ["/preview/**", "/do-not-track/me/too/"],
},
},
},
{
resolve: `gatsby-plugin-manifest`,
options: {
name: `Open Infrastructure Foundation`,
short_name: `Open Infrastructure Foundation`,
start_url: `/`,
background_color: `#ffffff`,
theme_color: `#f15b3e`,
icon: `src/img/icon.png`,
display: `standalone`,
},
},
`gatsby-plugin-remove-serviceworker`,
{
resolve: 'gatsby-plugin-netlify-cms',
options: {
modulePath: `${__dirname}/src/cms/cms.js`,
// @see https://github.com/netlify/netlify-cms/issues/1690#issuecomment-465078677
enableIdentityWidget: false,
/**
* Fixes Module not found: Error: Can't resolve 'path' bug.
* Webpack 5 doesn't include browser polyfills for node APIs by default anymore,
* so we need to provide them ourselves.
* @see https://github.com/postcss/postcss/issues/1509#issuecomment-772097567
* @see https://github.com/gatsbyjs/gatsby/issues/31475
* @see https://github.com/gatsbyjs/gatsby/issues/31179#issuecomment-844588682
*/
customizeWebpackConfig: (config) => {
config.resolve = {
...config.resolve,
fallback: {
...config.resolve.fallback,
path: require.resolve("path-browserify")
}
};
}
},
},
{
resolve: 'gatsby-plugin-purgecss', // purges all unused/unreferenced css rules
options: {
develop: true, // Activates purging in npm run develop
whitelistPatterns: [/^carousel/, /^projects-s/, /^company-level-/, /^more-recent-single-/, /^fa/, /^logo-/, /^modal/],
purgeOnly: ['/style'], // applies purging only on the bulma css file
},
}, // must be after other CSS plugins
{
resolve: 'gatsby-plugin-linkedin-insight',
options: {
partnerId: '2906612',
// Include LinkedIn Insight in development.
// Defaults to false meaning LinkedIn Insight will only be loaded in production.
includeInDevelopment: true
}
},
'gatsby-plugin-netlify', // make sure to keep it last in the array
],
}