-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-config.js
221 lines (217 loc) · 9.34 KB
/
gatsby-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
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
require("dotenv").config({
path: `.env`,
})
module.exports = {
siteMetadata: {
title: `Jennego`,
description: `Hobby photography portfolio site. Sourcing from ContentfulCMS and Wordpress.com. Made from default starter.`,
author: `@jennego`,
},
plugins: [
// `gatsby-plugin-image`, // screws up my layout somehow
`gatsby-plugin-sharp`,
`gatsby-transformer-sharp`,
`gatsby-plugin-transition-link`,
`gatsby-plugin-fontawesome-css`,
`gatsby-plugin-react-helmet`,
{
resolve: `gatsby-plugin-sass`,
options: {
sassOptions: {
includePaths: ["@bootstrap"],
},
},
},
{
resolve: `gatsby-source-filesystem`,
options: {
name: `images`,
path: `${__dirname}/src/images`,
},
},
{
resolve: `gatsby-plugin-manifest`,
options: {
name: `gatsby-starter-default`,
short_name: `starter`,
start_url: `/`,
background_color: `#663399`,
theme_color: `#663399`,
display: `minimal-ui`,
icon: `src/images/gatsby-icon.png`, // This path is relative to the root of the site.
},
},
{
resolve: `gatsby-plugin-breadcrumb`,
options: {
// useAutoGen: required 'true' to use autogen
useAutoGen: true,
// autoGenHomeLabel: optional 'Home' is default
autoGenHomeLabel: `Home`,
// exclude: optional, include this array to exclude paths you don't want to
// generate breadcrumbs for (see below for details).
exclude: [
`**/dev-404-page/**`,
`**/404/**`,
`**/404.html`,
`**/offline-plugin-app-shell-fallback/**`,
],
// isMatchOptions: optional, include this object to configure the wildcard-match library.
excludeOptions: {
separator: ".",
},
// crumbLabelUpdates: optional, update specific crumbLabels in the path
crumbLabelUpdates: [
{
pathname: "/writing",
crumbLabel: "Writing",
},
{
pathname: "/photos",
crumbLabel: "Photos",
},
{
pathname: "/blog",
crumbLabel: "Blog",
},
],
// trailingSlashes: optional, will add trailing slashes to the end
// of crumb pathnames. default is false
trailingSlashes: true,
// usePathPrefix: optional, if you are using pathPrefix above
// usePathPrefix: "/blog",
},
},
{
resolve: `gatsby-source-contentful`,
options: {
spaceId: `c7t97ojr0qrw`,
// Learn about environment variables: https://gatsby.dev/env-vars
accessToken: process.env.ACCESS_TOKEN,
},
},
{
resolve: "gatsby-source-wordpress",
options: {
minimizeDeprecationNotice: true,
/*
* The base URL of the WordPress site without the trailingslash and the protocol. This is required.
* Example : 'demo.wp-api.org' or 'www.example-site.com'
*/
baseUrl: "jennegoblog.wordpress.com",
// The protocol. This can be http or https.
protocol: "https",
// The rest api route prefix that your WordPress site is using.
// Sometimes this is modified by WordPress plugins.
// If not set, it uses the default of "wp-json"
restApiRoutePrefix: "wp-json",
// Indicates whether the site is hosted on wordpress.com.
// If false, then the assumption is made that the site is self hosted.
// If true, then the plugin will source its content on wordpress.com using the JSON REST API V2.
// If your site is hosted on wordpress.org, then set this to false.
hostingWPCOM: true,
// If useACF is true, then the source plugin will try to import the WordPress ACF Plugin contents.
// This feature is untested for sites hosted on wordpress.com.
// Defaults to true.
useACF: false,
// Include specific ACF Option Pages that have a set post ID
// Regardless if an ID is set, the default options route will still be retrieved
// Must be using V3 of ACF to REST to include these routes
// Example: `["option_page_1", "option_page_2"]` will include the proper ACF option
// routes with the ID option_page_1 and option_page_2
// The IDs provided to this array should correspond to the `post_id` value when defining your
// options page using the provided `acf_add_options_page` method, in your WordPress setup
// Dashes in IDs will be converted to underscores for use in GraphQL
acfOptionPageIds: [],
auth: {
// If auth.user and auth.pass are filled, then the source plugin will be allowed
// to access endpoints that are protected with .htaccess.
// htaccess_user: "your-htaccess-username",
// htaccess_pass: "your-htaccess-password",
// htaccess_sendImmediately: false,
// If hostingWPCOM is true then you will need to communicate with wordpress.com API
// in order to do that you need to create an app (of type Web) at https://developer.wordpress.com/apps/
// then add your clientId, clientSecret, username, and password here
// Learn about environment variables: https://www.gatsbyjs.org/docs/environment-variables
// If two-factor authentication is enabled then you need to create an Application-Specific Password,
// see https://en.support.wordpress.com/security/two-step-authentication/#application-specific-passwords
wpcom_app_clientSecret: process.env.WORDPRESS_CLIENT_SECRET,
wpcom_app_clientId: process.env.WORDPRESS_CLIENT_ID,
wpcom_user: "jennego@gmail.com",
wpcom_pass: process.env.WORDPRESS_PASSWORD,
// If you use "JWT Authentication for WP REST API" (https://wordpress.org/plugins/jwt-authentication-for-wp-rest-api/)
// or (https://github.com/jonathan-dejong/simple-jwt-authentication) requires jwt_base_path, path can be found in WordPress wp-api.
// plugin, you can specify user and password to obtain access token and use authenticated requests against WordPress REST API.
// jwt_user: process.env.JWT_USER,
// jwt_pass: process.env.JWT_PASSWORD,
// jwt_base_path: "/jwt-auth/v1/token", // Default - can skip if you are using https://wordpress.org/plugins/jwt-authentication-for-wp-rest-api/
},
// Set cookies that should be send with requests to WordPress as key value pairs
cookies: {},
// Set verboseOutput to true to display a verbose output on `npm run develop` or `npm run build`
// It can help you debug specific API Endpoints problems.
verboseOutput: false,
// Set how many pages are retrieved per API request.
perPage: 100,
// Search and Replace Urls across WordPress content.
// searchAndReplaceContentUrls: {
// sourceUrl: "https://source-url.com",
// replacementUrl: "https://replacement-url.com",
// },
// Set how many simultaneous requests are sent at once.
concurrentRequests: 10,
// Set WP REST API routes whitelists
// and blacklists using glob patterns.
// Defaults to whitelist the routes shown
// in the example below.
// See: https://github.com/isaacs/minimatch
// Example: `["/*/*/comments", "/yoast/**"]`
// ` will either include or exclude routes ending in `comments` and
// all routes that begin with `yoast` from fetch.
// Whitelisted routes using glob patterns
includedRoutes: [
"**/categories",
"**/posts",
"**/pages",
"**/media",
"**/tags",
"**/taxonomies",
"**/users",
],
// Blacklisted routes using glob patterns
// excludedRoutes: ["**/posts/1456"],
// Set this to keep media sizes.
// This option is particularly useful in case you need access to
// URLs for thumbnails, or any other media detail.
// Defaults to false
keepMediaSizes: false,
// use a custom normalizer which is applied after the built-in ones.
normalizer: function ({ entities }) {
return entities
},
// The normalizers option allows you to manipulate the array of internal
// normalizers that are applied to entities after they're fetched
// from WordPress.
// You can add your own normalizers to this array by adding an object
// that contains name and normalizer properties.
// Name is the name of your normalizer, and normalizer is a function that
// should return the array of entities that are passed to it.
// This is useful if you need more control over the order of normalizers,
// instead of your normalizer being applied after the built in normalizers (as is the case with the normalizer option).
normalizers: normalizers => [
...normalizers,
{
name: "nameOfTheFunction",
normalizer: function ({ entities }) {
// manipulate entities here
return entities
},
},
],
},
},
// this (optional) plugin enables Progressive Web App + Offline functionality
// To learn more, visit: https://gatsby.dev/offline
// `gatsby-plugin-offline`,
],
}