,
133 | ])
134 | },
135 | },
136 | }
137 | }
138 |
139 | describe(`develop-static-entry`, () => {
140 | test(`onPreRenderHTML can be used to replace headComponents`, done => {
141 | global.plugins = [fakeStylesPlugin, reverseHeadersPlugin]
142 |
143 | DevelopStaticEntry(`/about/`, (_, html) => {
144 | expect(html).toMatchSnapshot()
145 | done()
146 | })
147 | })
148 |
149 | test(`onPreRenderHTML can be used to replace postBodyComponents`, done => {
150 | global.plugins = [
151 | fakeComponentsPluginFactory(`Post`),
152 | reverseBodyComponentsPluginFactory(`Post`),
153 | ]
154 |
155 | DevelopStaticEntry(`/about/`, (_, html) => {
156 | expect(html).toMatchSnapshot()
157 | done()
158 | })
159 | })
160 |
161 | test(`onPreRenderHTML can be used to replace preBodyComponents`, done => {
162 | global.plugins = [
163 | fakeComponentsPluginFactory(`Pre`),
164 | reverseBodyComponentsPluginFactory(`Pre`),
165 | ]
166 |
167 | DevelopStaticEntry(`/about/`, (_, html) => {
168 | expect(html).toMatchSnapshot()
169 | done()
170 | })
171 | })
172 |
173 | test(`onPreRenderHTML adds metatag note for development environment`, done => {
174 | DevelopStaticEntry(`/about/`, (_, html) => {
175 | expect(html).toContain(
176 | ``
177 | )
178 | done()
179 | })
180 | })
181 |
182 | test(`onPreRenderHTML adds metatag note for development environment after replaceHeadComponents`, done => {
183 | global.plugins = [reverseHeadersPlugin]
184 |
185 | DevelopStaticEntry(`/about/`, (_, html) => {
186 | expect(html).toContain(
187 | ``
188 | )
189 | done()
190 | })
191 | })
192 | })
193 |
194 | describe(`static-entry sanity checks`, () => {
195 | beforeEach(() => {
196 | global.__PATH_PREFIX__ = ``
197 | global.__BASE_PATH__ = ``
198 | global.__ASSET_PREFIX__ = ``
199 | })
200 |
201 | const methodsToCheck = [
202 | `replaceHeadComponents`,
203 | `replacePreBodyComponents`,
204 | `replacePostBodyComponents`,
205 | ]
206 |
207 | methodsToCheck.forEach(methodName => {
208 | test(`${methodName} can filter out null value`, done => {
209 | const plugin = injectValuePlugin(`onPreRenderHTML`, methodName, null)
210 | global.plugins = [plugin, checkNonEmptyHeadersPlugin]
211 |
212 | StaticEntry(`/about/`, (_, html) => {
213 | done()
214 | })
215 | })
216 |
217 | test(`${methodName} can filter out null values`, done => {
218 | const plugin = injectValuePlugin(`onPreRenderHTML`, methodName, [
219 | null,
220 | null,
221 | ])
222 | global.plugins = [plugin, checkNonEmptyHeadersPlugin]
223 |
224 | StaticEntry(`/about/`, (_, html) => {
225 | done()
226 | })
227 | })
228 |
229 | test(`${methodName} can filter out empty array`, done => {
230 | const plugin = injectValuePlugin(`onPreRenderHTML`, methodName, [])
231 | global.plugins = [plugin, checkNonEmptyHeadersPlugin]
232 |
233 | StaticEntry(`/about/`, (_, html) => {
234 | done()
235 | })
236 | })
237 |
238 | test(`${methodName} can filter out empty arrays`, done => {
239 | const plugin = injectValuePlugin(`onPreRenderHTML`, methodName, [[], []])
240 | global.plugins = [plugin, checkNonEmptyHeadersPlugin]
241 |
242 | StaticEntry(`/about/`, (_, html) => {
243 | done()
244 | })
245 | })
246 |
247 | test(`${methodName} can flatten arrays`, done => {
248 | const plugin = injectValuePlugin(`onPreRenderHTML`, methodName, [
249 | ,
250 | ,
251 | ,
252 | [],
253 | ])
254 | global.plugins = [plugin, checkNonEmptyHeadersPlugin]
255 |
256 | StaticEntry(`/about/`, (_, html) => {
257 | done()
258 | })
259 | })
260 | })
261 | })
262 |
263 | describe(`static-entry`, () => {
264 | beforeEach(() => {
265 | global.__PATH_PREFIX__ = ``
266 | global.__BASE_PATH__ = ``
267 | fs.readFileSync.mockImplementation(file => MOCK_FILE_INFO[file])
268 | })
269 |
270 | test(`onPreRenderHTML can be used to replace headComponents`, done => {
271 | global.plugins = [fakeStylesPlugin, reverseHeadersPlugin]
272 |
273 | StaticEntry(`/about/`, (_, html) => {
274 | expect(html).toMatchSnapshot()
275 | done()
276 | })
277 | })
278 |
279 | test(`onPreRenderHTML can be used to replace postBodyComponents`, done => {
280 | global.plugins = [
281 | fakeComponentsPluginFactory(`Post`),
282 | reverseBodyComponentsPluginFactory(`Post`),
283 | ]
284 |
285 | StaticEntry(`/about/`, (_, html) => {
286 | expect(html).toMatchSnapshot()
287 | done()
288 | })
289 | })
290 |
291 | test(`onPreRenderHTML can be used to replace preBodyComponents`, done => {
292 | global.plugins = [
293 | fakeComponentsPluginFactory(`Pre`),
294 | reverseBodyComponentsPluginFactory(`Pre`),
295 | ]
296 |
297 | StaticEntry(`/about/`, (_, html) => {
298 | expect(html).toMatchSnapshot()
299 | done()
300 | })
301 | })
302 |
303 | test(`onPreRenderHTML does not add metatag note for development environment`, done => {
304 | StaticEntry(`/about/`, (_, html) => {
305 | expect(html).not.toContain(
306 | ``
307 | )
308 | done()
309 | })
310 | })
311 | })
312 |
313 | describe(`sanitizeComponents`, () => {
314 | let sanitizeComponents
315 |
316 | beforeEach(() => {
317 | fs.readFileSync.mockImplementation(file => MOCK_FILE_INFO[file])
318 | sanitizeComponents = require(`../static-entry`).sanitizeComponents
319 | })
320 |
321 | it(`strips assetPrefix for manifest link`, () => {
322 | global.__PATH_PREFIX__ = `https://gatsbyjs.org/blog`
323 | global.__BASE_PATH__ = `/blog`
324 | global.__ASSET_PREFIX__ = `https://gatsbyjs.org`
325 |
326 | const sanitizedComponents = sanitizeComponents([
327 | ,
332 | ])
333 | expect(sanitizedComponents[0].props.href).toBe(`/blog/manifest.webmanifest`)
334 | })
335 | })
336 |
--------------------------------------------------------------------------------
/.cache/__tests__/strip-prefix.js:
--------------------------------------------------------------------------------
1 | const stripPrefix = require(`../strip-prefix`).default
2 |
3 | describe(`strip-prefix`, () => {
4 | it(`strips a prefix`, () => {
5 | expect(stripPrefix(`/foo/bar/`, `/foo`)).toBe(`/bar/`)
6 | })
7 |
8 | it(`strips first instance only`, () => {
9 | expect(stripPrefix(`/foo/foo/bar/`, `/foo`)).toBe(`/foo/bar/`)
10 | })
11 |
12 | it(`strips full instance only`, () => {
13 | expect(stripPrefix(`/footest/`, `/foo`)).toBe(`/footest/`)
14 | })
15 |
16 | it(`ignores prefix appearing elsewhere in the string`, () => {
17 | expect(stripPrefix(`/foo/bar/`, `bar`)).toBe(`/foo/bar/`)
18 | })
19 |
20 | it(`ignores a non-existent prefix`, () => {
21 | expect(stripPrefix(`/bar`, `/foo`)).toBe(`/bar`)
22 | })
23 |
24 | it(`returns input str if no prefix is provided`, () => {
25 | expect(stripPrefix(`/bar`)).toBe(`/bar`)
26 | })
27 | })
28 |
--------------------------------------------------------------------------------
/.cache/api-runner-browser-plugins.js:
--------------------------------------------------------------------------------
1 | module.exports = [{
2 | plugin: require('../node_modules/gatsby-plugin-manifest/gatsby-browser.js'),
3 | options: {"plugins":[],"name":"gatsby-starter-default","short_name":"starter","start_url":"/","background_color":"#663399","theme_color":"#663399","display":"minimal-ui","icon":"src/images/gatsby-icon.png"},
4 | },{
5 | plugin: require('../gatsby-browser.js'),
6 | options: {"plugins":[]},
7 | }]
8 |
--------------------------------------------------------------------------------
/.cache/api-runner-browser.js:
--------------------------------------------------------------------------------
1 | const plugins = require(`./api-runner-browser-plugins`)
2 | const {
3 | getResourcesForPathname,
4 | getResourcesForPathnameSync,
5 | getResourceURLsForPathname,
6 | loadPage,
7 | loadPageSync,
8 | } = require(`./loader`).publicLoader
9 |
10 | exports.apiRunner = (api, args = {}, defaultReturn, argTransform) => {
11 | // Hooks for gatsby-cypress's API handler
12 | if (process.env.CYPRESS_SUPPORT) {
13 | if (window.___apiHandler) {
14 | window.___apiHandler(api)
15 | } else if (window.___resolvedAPIs) {
16 | window.___resolvedAPIs.push(api)
17 | } else {
18 | window.___resolvedAPIs = [api]
19 | }
20 | }
21 |
22 | let results = plugins.map(plugin => {
23 | if (!plugin.plugin[api]) {
24 | return undefined
25 | }
26 |
27 | // Deprecated April 2019. Use `loadPageSync` instead
28 | args.getResourcesForPathnameSync = getResourcesForPathnameSync
29 | // Deprecated April 2019. Use `loadPage` instead
30 | args.getResourcesForPathname = getResourcesForPathname
31 | args.getResourceURLsForPathname = getResourceURLsForPathname
32 | args.loadPage = loadPage
33 | args.loadPageSync = loadPageSync
34 |
35 | const result = plugin.plugin[api](args, plugin.options)
36 | if (result && argTransform) {
37 | args = argTransform({ args, result, plugin })
38 | }
39 | return result
40 | })
41 |
42 | // Filter out undefined results.
43 | results = results.filter(result => typeof result !== `undefined`)
44 |
45 | if (results.length > 0) {
46 | return results
47 | } else if (defaultReturn) {
48 | return [defaultReturn]
49 | } else {
50 | return []
51 | }
52 | }
53 |
54 | exports.apiRunnerAsync = (api, args, defaultReturn) =>
55 | plugins.reduce(
56 | (previous, next) =>
57 | next.plugin[api]
58 | ? previous.then(() => next.plugin[api](args, next.options))
59 | : previous,
60 | Promise.resolve()
61 | )
62 |
--------------------------------------------------------------------------------
/.cache/api-runner-ssr.js:
--------------------------------------------------------------------------------
1 | var plugins = [{
2 | plugin: require('/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/gatsby-plugin-react-helmet/gatsby-ssr'),
3 | options: {"plugins":[]},
4 | },{
5 | plugin: require('/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/gatsby-plugin-manifest/gatsby-ssr'),
6 | options: {"plugins":[],"name":"gatsby-starter-default","short_name":"starter","start_url":"/","background_color":"#663399","theme_color":"#663399","display":"minimal-ui","icon":"src/images/gatsby-icon.png"},
7 | }]
8 | // During bootstrap, we write requires at top of this file which looks like:
9 | // var plugins = [
10 | // {
11 | // plugin: require("/path/to/plugin1/gatsby-ssr.js"),
12 | // options: { ... },
13 | // },
14 | // {
15 | // plugin: require("/path/to/plugin2/gatsby-ssr.js"),
16 | // options: { ... },
17 | // },
18 | // ]
19 |
20 | const apis = require(`./api-ssr-docs`)
21 |
22 | // Run the specified API in any plugins that have implemented it
23 | module.exports = (api, args, defaultReturn, argTransform) => {
24 | if (!apis[api]) {
25 | console.log(`This API doesn't exist`, api)
26 | }
27 |
28 | // Run each plugin in series.
29 | // eslint-disable-next-line no-undef
30 | let results = plugins.map(plugin => {
31 | if (!plugin.plugin[api]) {
32 | return undefined
33 | }
34 | const result = plugin.plugin[api](args, plugin.options)
35 | if (result && argTransform) {
36 | args = argTransform({ args, result })
37 | }
38 | return result
39 | })
40 |
41 | // Filter out undefined results.
42 | results = results.filter(result => typeof result !== `undefined`)
43 |
44 | if (results.length > 0) {
45 | return results
46 | } else {
47 | return [defaultReturn]
48 | }
49 | }
50 |
--------------------------------------------------------------------------------
/.cache/api-ssr-docs.js:
--------------------------------------------------------------------------------
1 | /**
2 | * Object containing options defined in `gatsby-config.js`
3 | * @typedef {object} pluginOptions
4 | */
5 |
6 | /**
7 | * Replace the default server renderer. This is useful for integration with
8 | * Redux, css-in-js libraries, etc. that need custom setups for server
9 | * rendering.
10 | * @param {object} $0
11 | * @param {string} $0.pathname The pathname of the page currently being rendered.
12 | * @param {function} $0.replaceBodyHTMLString Call this with the HTML string
13 | * you render. **WARNING** if multiple plugins implement this API it's the
14 | * last plugin that "wins". TODO implement an automated warning against this.
15 | * @param {function} $0.setHeadComponents Takes an array of components as its
16 | * first argument which are added to the `headComponents` array which is passed
17 | * to the `html.js` component.
18 | * @param {function} $0.setHtmlAttributes Takes an object of props which will
19 | * spread into the `` component.
20 | * @param {function} $0.setBodyAttributes Takes an object of props which will
21 | * spread into the `` component.
22 | * @param {function} $0.setPreBodyComponents Takes an array of components as its
23 | * first argument which are added to the `preBodyComponents` array which is passed
24 | * to the `html.js` component.
25 | * @param {function} $0.setPostBodyComponents Takes an array of components as its
26 | * first argument which are added to the `postBodyComponents` array which is passed
27 | * to the `html.js` component.
28 | * @param {function} $0.setBodyProps Takes an object of data which
29 | * is merged with other body props and passed to `html.js` as `bodyProps`.
30 | * @param {pluginOptions} pluginOptions
31 | * @example
32 | * // From gatsby-plugin-glamor
33 | * const { renderToString } = require("react-dom/server")
34 | * const inline = require("glamor-inline")
35 | *
36 | * exports.replaceRenderer = ({ bodyComponent, replaceBodyHTMLString }) => {
37 | * const bodyHTML = renderToString(bodyComponent)
38 | * const inlinedHTML = inline(bodyHTML)
39 | *
40 | * replaceBodyHTMLString(inlinedHTML)
41 | * }
42 | */
43 | exports.replaceRenderer = true
44 |
45 | /**
46 | * Called after every page Gatsby server renders while building HTML so you can
47 | * set head and body components to be rendered in your `html.js`.
48 | *
49 | * Gatsby does a two-pass render for HTML. It loops through your pages first
50 | * rendering only the body and then takes the result body HTML string and
51 | * passes it as the `body` prop to your `html.js` to complete the render.
52 | *
53 | * It's often handy to be able to send custom components to your `html.js`.
54 | * For example, it's a very common pattern for React.js libraries that
55 | * support server rendering to pull out data generated during the render to
56 | * add to your HTML.
57 | *
58 | * Using this API over [`replaceRenderer`](#replaceRenderer) is preferable as
59 | * multiple plugins can implement this API where only one plugin can take
60 | * over server rendering. However, if your plugin requires taking over server
61 | * rendering then that's the one to
62 | * use
63 | * @param {object} $0
64 | * @param {string} $0.pathname The pathname of the page currently being rendered.
65 | * @param {function} $0.setHeadComponents Takes an array of components as its
66 | * first argument which are added to the `headComponents` array which is passed
67 | * to the `html.js` component.
68 | * @param {function} $0.setHtmlAttributes Takes an object of props which will
69 | * spread into the `` component.
70 | * @param {function} $0.setBodyAttributes Takes an object of props which will
71 | * spread into the `` component.
72 | * @param {function} $0.setPreBodyComponents Takes an array of components as its
73 | * first argument which are added to the `preBodyComponents` array which is passed
74 | * to the `html.js` component.
75 | * @param {function} $0.setPostBodyComponents Takes an array of components as its
76 | * first argument which are added to the `postBodyComponents` array which is passed
77 | * to the `html.js` component.
78 | * @param {function} $0.setBodyProps Takes an object of data which
79 | * is merged with other body props and passed to `html.js` as `bodyProps`.
80 | * @param {pluginOptions} pluginOptions
81 | * @example
82 | * const { Helmet } = require("react-helmet")
83 | *
84 | * exports.onRenderBody = (
85 | * { setHeadComponents, setHtmlAttributes, setBodyAttributes },
86 | * pluginOptions
87 | * ) => {
88 | * const helmet = Helmet.renderStatic()
89 | * setHtmlAttributes(helmet.htmlAttributes.toComponent())
90 | * setBodyAttributes(helmet.bodyAttributes.toComponent())
91 | * setHeadComponents([
92 | * helmet.title.toComponent(),
93 | * helmet.link.toComponent(),
94 | * helmet.meta.toComponent(),
95 | * helmet.noscript.toComponent(),
96 | * helmet.script.toComponent(),
97 | * helmet.style.toComponent(),
98 | * ])
99 | * }
100 | */
101 | exports.onRenderBody = true
102 |
103 | /**
104 | * Called after every page Gatsby server renders while building HTML so you can
105 | * replace head components to be rendered in your `html.js`. This is useful if
106 | * you need to reorder scripts or styles added by other plugins.
107 | * @param {object} $0
108 | * @param {string} $0.pathname The pathname of the page currently being rendered.
109 | * @param {Array} $0.getHeadComponents Returns the current `headComponents` array.
110 | * @param {function} $0.replaceHeadComponents Takes an array of components as its
111 | * first argument which replace the `headComponents` array which is passed
112 | * to the `html.js` component. **WARNING** if multiple plugins implement this
113 | * API it's the last plugin that "wins".
114 | * @param {Array} $0.getPreBodyComponents Returns the current `preBodyComponents` array.
115 | * @param {function} $0.replacePreBodyComponents Takes an array of components as its
116 | * first argument which replace the `preBodyComponents` array which is passed
117 | * to the `html.js` component. **WARNING** if multiple plugins implement this
118 | * API it's the last plugin that "wins".
119 | * @param {Array} $0.getPostBodyComponents Returns the current `postBodyComponents` array.
120 | * @param {function} $0.replacePostBodyComponents Takes an array of components as its
121 | * first argument which replace the `postBodyComponents` array which is passed
122 | * to the `html.js` component. **WARNING** if multiple plugins implement this
123 | * API it's the last plugin that "wins".
124 | * @param {pluginOptions} pluginOptions
125 | * @example
126 | * // Move Typography.js styles to the top of the head section so they're loaded first.
127 | * exports.onPreRenderHTML = ({ getHeadComponents, replaceHeadComponents }) => {
128 | * const headComponents = getHeadComponents()
129 | * headComponents.sort((x, y) => {
130 | * if (x.key === 'TypographyStyle') {
131 | * return -1
132 | * } else if (y.key === 'TypographyStyle') {
133 | * return 1
134 | * }
135 | * return 0
136 | * })
137 | * replaceHeadComponents(headComponents)
138 | * }
139 | */
140 | exports.onPreRenderHTML = true
141 |
142 | /**
143 | * Allow a plugin to wrap the page element.
144 | *
145 | * This is useful for setting wrapper components around pages that won't get
146 | * unmounted on page changes. For setting Provider components, use [wrapRootElement](#wrapRootElement).
147 | *
148 | * _Note:_
149 | * There is an equivalent hook in Gatsby's [Browser API](/docs/browser-apis/#wrapPageElement).
150 | * It is recommended to use both APIs together.
151 | * For example usage, check out [Using i18n](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-i18n).
152 | * @param {object} $0
153 | * @param {ReactNode} $0.element The "Page" React Element built by Gatsby.
154 | * @param {object} $0.props Props object used by page.
155 | * @param {pluginOptions} pluginOptions
156 | * @returns {ReactNode} Wrapped element
157 | * @example
158 | * const React = require("react")
159 | * const Layout = require("./src/components/layout").default
160 | *
161 | * exports.wrapPageElement = ({ element, props }) => {
162 | * // props provide same data to Layout as Page element will get
163 | * // including location, data, etc - you don't need to pass it
164 | * return {element}
165 | * }
166 | */
167 | exports.wrapPageElement = true
168 |
169 | /**
170 | * Allow a plugin to wrap the root element.
171 | *
172 | * This is useful to set up any Provider components that will wrap your application.
173 | * For setting persistent UI elements around pages use [wrapPageElement](#wrapPageElement).
174 | *
175 | * _Note:_
176 | * There is an equivalent hook in Gatsby's [Browser API](/docs/browser-apis/#wrapRootElement).
177 | * It is recommended to use both APIs together.
178 | * For example usage, check out [Using redux](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-redux).
179 | * @param {object} $0
180 | * @param {ReactNode} $0.element The "Root" React Element built by Gatsby.
181 | * @param {pluginOptions} pluginOptions
182 | * @returns {ReactNode} Wrapped element
183 | * @example
184 | * const React = require("react")
185 | * const { Provider } = require("react-redux")
186 | *
187 | * const createStore = require("./src/state/createStore")
188 | * const store = createStore()
189 | *
190 | * exports.wrapRootElement = ({ element }) => {
191 | * return (
192 | *
193 | * {element}
194 | *
195 | * )
196 | * }
197 | */
198 | exports.wrapRootElement = true
199 |
--------------------------------------------------------------------------------
/.cache/app.js:
--------------------------------------------------------------------------------
1 | import React from "react"
2 | import ReactDOM from "react-dom"
3 | import domReady from "@mikaelkristiansson/domready"
4 |
5 | import socketIo from "./socketIo"
6 | import emitter from "./emitter"
7 | import { apiRunner, apiRunnerAsync } from "./api-runner-browser"
8 | import { setLoader, publicLoader } from "./loader"
9 | import DevLoader from "./dev-loader"
10 | import syncRequires from "./sync-requires"
11 | // Generated during bootstrap
12 | import matchPaths from "./match-paths.json"
13 |
14 | window.___emitter = emitter
15 |
16 | const loader = new DevLoader(syncRequires, matchPaths)
17 | setLoader(loader)
18 | loader.setApiRunner(apiRunner)
19 |
20 | window.___loader = publicLoader
21 |
22 | // Let the site/plugins run code very early.
23 | apiRunnerAsync(`onClientEntry`).then(() => {
24 | // Hook up the client to socket.io on server
25 | const socket = socketIo()
26 | if (socket) {
27 | socket.on(`reload`, () => {
28 | window.location.reload()
29 | })
30 | }
31 |
32 | /**
33 | * Service Workers are persistent by nature. They stick around,
34 | * serving a cached version of the site if they aren't removed.
35 | * This is especially frustrating when you need to test the
36 | * production build on your local machine.
37 | *
38 | * Let's warn if we find service workers in development.
39 | */
40 | if (`serviceWorker` in navigator) {
41 | navigator.serviceWorker.getRegistrations().then(registrations => {
42 | if (registrations.length > 0)
43 | console.warn(
44 | `Warning: found one or more service workers present.`,
45 | `If your site isn't behaving as expected, you might want to remove these.`,
46 | registrations
47 | )
48 | })
49 | }
50 |
51 | const rootElement = document.getElementById(`___gatsby`)
52 |
53 | const renderer = apiRunner(
54 | `replaceHydrateFunction`,
55 | undefined,
56 | ReactDOM.render
57 | )[0]
58 |
59 | Promise.all([
60 | loader.loadPage(`/dev-404-page/`),
61 | loader.loadPage(`/404.html`),
62 | loader.loadPage(window.location.pathname),
63 | ]).then(() => {
64 | const preferDefault = m => (m && m.default) || m
65 | let Root = preferDefault(require(`./root`))
66 | domReady(() => {
67 | renderer(, rootElement, () => {
68 | apiRunner(`onInitialClientRender`)
69 | })
70 | })
71 | })
72 | })
73 |
--------------------------------------------------------------------------------
/.cache/async-requires.js:
--------------------------------------------------------------------------------
1 | // prefer default export if available
2 | const preferDefault = m => m && m.default || m
3 |
4 | exports.components = {
5 | "component---cache-dev-404-page-js": () => import("./dev-404-page.js" /* webpackChunkName: "component---cache-dev-404-page-js" */),
6 | "component---src-pages-404-js": () => import("./../src/pages/404.js" /* webpackChunkName: "component---src-pages-404-js" */),
7 | "component---src-pages-index-js": () => import("./../src/pages/index.js" /* webpackChunkName: "component---src-pages-index-js" */),
8 | "component---src-pages-page-2-tsx": () => import("./../src/pages/page-2.tsx" /* webpackChunkName: "component---src-pages-page-2-tsx" */)
9 | }
10 |
11 |
--------------------------------------------------------------------------------
/.cache/babelState.json:
--------------------------------------------------------------------------------
1 | {
2 | "stages": {
3 | "develop": {
4 | "plugins": [
5 | {
6 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-optional-chaining/lib/index.js",
7 | "options": {}
8 | },
9 | {
10 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-nullish-coalescing-operator/lib/index.js",
11 | "options": {}
12 | },
13 | {
14 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-numeric-separator/lib/index.js",
15 | "options": {}
16 | }
17 | ],
18 | "presets": [
19 | {
20 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/preset-typescript/lib/index.js",
21 | "options": {
22 | "plugins": []
23 | }
24 | }
25 | ],
26 | "options": {
27 | "cacheDirectory": true,
28 | "sourceType": "unambiguous"
29 | }
30 | },
31 | "develop-html": {
32 | "plugins": [
33 | {
34 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-optional-chaining/lib/index.js",
35 | "options": {}
36 | },
37 | {
38 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-nullish-coalescing-operator/lib/index.js",
39 | "options": {}
40 | },
41 | {
42 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-numeric-separator/lib/index.js",
43 | "options": {}
44 | }
45 | ],
46 | "presets": [
47 | {
48 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/preset-typescript/lib/index.js",
49 | "options": {
50 | "plugins": []
51 | }
52 | }
53 | ],
54 | "options": {
55 | "cacheDirectory": true,
56 | "sourceType": "unambiguous"
57 | }
58 | },
59 | "build-html": {
60 | "plugins": [
61 | {
62 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-optional-chaining/lib/index.js",
63 | "options": {}
64 | },
65 | {
66 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-nullish-coalescing-operator/lib/index.js",
67 | "options": {}
68 | },
69 | {
70 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-numeric-separator/lib/index.js",
71 | "options": {}
72 | }
73 | ],
74 | "presets": [
75 | {
76 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/preset-typescript/lib/index.js",
77 | "options": {
78 | "plugins": []
79 | }
80 | }
81 | ],
82 | "options": {
83 | "cacheDirectory": true,
84 | "sourceType": "unambiguous"
85 | }
86 | },
87 | "build-javascript": {
88 | "plugins": [
89 | {
90 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-optional-chaining/lib/index.js",
91 | "options": {}
92 | },
93 | {
94 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-nullish-coalescing-operator/lib/index.js",
95 | "options": {}
96 | },
97 | {
98 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/plugin-proposal-numeric-separator/lib/index.js",
99 | "options": {}
100 | }
101 | ],
102 | "presets": [
103 | {
104 | "name": "/Users/hofheins/Desktop/Stevens Things/zorg/react-tailwind-starter-plate/node_modules/@babel/preset-typescript/lib/index.js",
105 | "options": {
106 | "plugins": []
107 | }
108 | }
109 | ],
110 | "options": {
111 | "cacheDirectory": true,
112 | "sourceType": "unambiguous"
113 | }
114 | }
115 | },
116 | "browserslist": [
117 | ">0.25%",
118 | "not dead"
119 | ]
120 | }
--------------------------------------------------------------------------------
/.cache/caches/gatsby-transformer-sharp/diskstore-66c1da6000f7fd2228748e1552fc342e.json:
--------------------------------------------------------------------------------
1 | {"expireTime":9007200844311005000,"key":"b3a515ff-c444-5fb3-b233-d963bda7871e{\"duotone\":false,\"grayscale\":false,\"rotate\":0,\"trim\":false,\"toFormat\":\"png\",\"toFormatBase64\":\"\",\"cropFocus\":17,\"fit\":\"cover\",\"width\":20,\"height\":20}","val":{"src":"","width":20,"height":20,"aspectRatio":1,"originalName":"gatsby-astronaut.png"}}
--------------------------------------------------------------------------------
/.cache/commonjs/api-runner-browser-plugins.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | // During bootstrap, we write requires at top of this file which looks
4 | // basically like:
5 | // module.exports = [
6 | // {
7 | // plugin: require("/path/to/plugin1/gatsby-browser.js"),
8 | // options: { ... },
9 | // },
10 | // {
11 | // plugin: require("/path/to/plugin2/gatsby-browser.js"),
12 | // options: { ... },
13 | // },
14 | // ]
15 | module.exports = [];
--------------------------------------------------------------------------------
/.cache/commonjs/api-runner-browser.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | const plugins = require(`./api-runner-browser-plugins`);
4 |
5 | const {
6 | getResourcesForPathname,
7 | getResourcesForPathnameSync,
8 | getResourceURLsForPathname,
9 | loadPage,
10 | loadPageSync
11 | } = require(`./loader`).publicLoader;
12 |
13 | exports.apiRunner = (api, args = {}, defaultReturn, argTransform) => {
14 | // Hooks for gatsby-cypress's API handler
15 | if (process.env.CYPRESS_SUPPORT) {
16 | if (window.___apiHandler) {
17 | window.___apiHandler(api);
18 | } else if (window.___resolvedAPIs) {
19 | window.___resolvedAPIs.push(api);
20 | } else {
21 | window.___resolvedAPIs = [api];
22 | }
23 | }
24 |
25 | let results = plugins.map(plugin => {
26 | if (!plugin.plugin[api]) {
27 | return undefined;
28 | } // Deprecated April 2019. Use `loadPageSync` instead
29 |
30 |
31 | args.getResourcesForPathnameSync = getResourcesForPathnameSync; // Deprecated April 2019. Use `loadPage` instead
32 |
33 | args.getResourcesForPathname = getResourcesForPathname;
34 | args.getResourceURLsForPathname = getResourceURLsForPathname;
35 | args.loadPage = loadPage;
36 | args.loadPageSync = loadPageSync;
37 | const result = plugin.plugin[api](args, plugin.options);
38 |
39 | if (result && argTransform) {
40 | args = argTransform({
41 | args,
42 | result,
43 | plugin
44 | });
45 | }
46 |
47 | return result;
48 | }); // Filter out undefined results.
49 |
50 | results = results.filter(result => typeof result !== `undefined`);
51 |
52 | if (results.length > 0) {
53 | return results;
54 | } else if (defaultReturn) {
55 | return [defaultReturn];
56 | } else {
57 | return [];
58 | }
59 | };
60 |
61 | exports.apiRunnerAsync = (api, args, defaultReturn) => plugins.reduce((previous, next) => next.plugin[api] ? previous.then(() => next.plugin[api](args, next.options)) : previous, Promise.resolve());
--------------------------------------------------------------------------------
/.cache/commonjs/api-runner-ssr.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | // During bootstrap, we write requires at top of this file which looks like:
4 | // var plugins = [
5 | // {
6 | // plugin: require("/path/to/plugin1/gatsby-ssr.js"),
7 | // options: { ... },
8 | // },
9 | // {
10 | // plugin: require("/path/to/plugin2/gatsby-ssr.js"),
11 | // options: { ... },
12 | // },
13 | // ]
14 | const apis = require(`./api-ssr-docs`); // Run the specified API in any plugins that have implemented it
15 |
16 |
17 | module.exports = (api, args, defaultReturn, argTransform) => {
18 | if (!apis[api]) {
19 | console.log(`This API doesn't exist`, api);
20 | } // Run each plugin in series.
21 | // eslint-disable-next-line no-undef
22 |
23 |
24 | let results = plugins.map(plugin => {
25 | if (!plugin.plugin[api]) {
26 | return undefined;
27 | }
28 |
29 | const result = plugin.plugin[api](args, plugin.options);
30 |
31 | if (result && argTransform) {
32 | args = argTransform({
33 | args,
34 | result
35 | });
36 | }
37 |
38 | return result;
39 | }); // Filter out undefined results.
40 |
41 | results = results.filter(result => typeof result !== `undefined`);
42 |
43 | if (results.length > 0) {
44 | return results;
45 | } else {
46 | return [defaultReturn];
47 | }
48 | };
--------------------------------------------------------------------------------
/.cache/commonjs/api-ssr-docs.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | /**
4 | * Object containing options defined in `gatsby-config.js`
5 | * @typedef {object} pluginOptions
6 | */
7 |
8 | /**
9 | * Replace the default server renderer. This is useful for integration with
10 | * Redux, css-in-js libraries, etc. that need custom setups for server
11 | * rendering.
12 | * @param {object} $0
13 | * @param {string} $0.pathname The pathname of the page currently being rendered.
14 | * @param {function} $0.replaceBodyHTMLString Call this with the HTML string
15 | * you render. **WARNING** if multiple plugins implement this API it's the
16 | * last plugin that "wins". TODO implement an automated warning against this.
17 | * @param {function} $0.setHeadComponents Takes an array of components as its
18 | * first argument which are added to the `headComponents` array which is passed
19 | * to the `html.js` component.
20 | * @param {function} $0.setHtmlAttributes Takes an object of props which will
21 | * spread into the `` component.
22 | * @param {function} $0.setBodyAttributes Takes an object of props which will
23 | * spread into the `` component.
24 | * @param {function} $0.setPreBodyComponents Takes an array of components as its
25 | * first argument which are added to the `preBodyComponents` array which is passed
26 | * to the `html.js` component.
27 | * @param {function} $0.setPostBodyComponents Takes an array of components as its
28 | * first argument which are added to the `postBodyComponents` array which is passed
29 | * to the `html.js` component.
30 | * @param {function} $0.setBodyProps Takes an object of data which
31 | * is merged with other body props and passed to `html.js` as `bodyProps`.
32 | * @param {pluginOptions} pluginOptions
33 | * @example
34 | * // From gatsby-plugin-glamor
35 | * const { renderToString } = require("react-dom/server")
36 | * const inline = require("glamor-inline")
37 | *
38 | * exports.replaceRenderer = ({ bodyComponent, replaceBodyHTMLString }) => {
39 | * const bodyHTML = renderToString(bodyComponent)
40 | * const inlinedHTML = inline(bodyHTML)
41 | *
42 | * replaceBodyHTMLString(inlinedHTML)
43 | * }
44 | */
45 | exports.replaceRenderer = true;
46 | /**
47 | * Called after every page Gatsby server renders while building HTML so you can
48 | * set head and body components to be rendered in your `html.js`.
49 | *
50 | * Gatsby does a two-pass render for HTML. It loops through your pages first
51 | * rendering only the body and then takes the result body HTML string and
52 | * passes it as the `body` prop to your `html.js` to complete the render.
53 | *
54 | * It's often handy to be able to send custom components to your `html.js`.
55 | * For example, it's a very common pattern for React.js libraries that
56 | * support server rendering to pull out data generated during the render to
57 | * add to your HTML.
58 | *
59 | * Using this API over [`replaceRenderer`](#replaceRenderer) is preferable as
60 | * multiple plugins can implement this API where only one plugin can take
61 | * over server rendering. However, if your plugin requires taking over server
62 | * rendering then that's the one to
63 | * use
64 | * @param {object} $0
65 | * @param {string} $0.pathname The pathname of the page currently being rendered.
66 | * @param {function} $0.setHeadComponents Takes an array of components as its
67 | * first argument which are added to the `headComponents` array which is passed
68 | * to the `html.js` component.
69 | * @param {function} $0.setHtmlAttributes Takes an object of props which will
70 | * spread into the `` component.
71 | * @param {function} $0.setBodyAttributes Takes an object of props which will
72 | * spread into the `` component.
73 | * @param {function} $0.setPreBodyComponents Takes an array of components as its
74 | * first argument which are added to the `preBodyComponents` array which is passed
75 | * to the `html.js` component.
76 | * @param {function} $0.setPostBodyComponents Takes an array of components as its
77 | * first argument which are added to the `postBodyComponents` array which is passed
78 | * to the `html.js` component.
79 | * @param {function} $0.setBodyProps Takes an object of data which
80 | * is merged with other body props and passed to `html.js` as `bodyProps`.
81 | * @param {pluginOptions} pluginOptions
82 | * @example
83 | * const { Helmet } = require("react-helmet")
84 | *
85 | * exports.onRenderBody = (
86 | * { setHeadComponents, setHtmlAttributes, setBodyAttributes },
87 | * pluginOptions
88 | * ) => {
89 | * const helmet = Helmet.renderStatic()
90 | * setHtmlAttributes(helmet.htmlAttributes.toComponent())
91 | * setBodyAttributes(helmet.bodyAttributes.toComponent())
92 | * setHeadComponents([
93 | * helmet.title.toComponent(),
94 | * helmet.link.toComponent(),
95 | * helmet.meta.toComponent(),
96 | * helmet.noscript.toComponent(),
97 | * helmet.script.toComponent(),
98 | * helmet.style.toComponent(),
99 | * ])
100 | * }
101 | */
102 |
103 | exports.onRenderBody = true;
104 | /**
105 | * Called after every page Gatsby server renders while building HTML so you can
106 | * replace head components to be rendered in your `html.js`. This is useful if
107 | * you need to reorder scripts or styles added by other plugins.
108 | * @param {object} $0
109 | * @param {string} $0.pathname The pathname of the page currently being rendered.
110 | * @param {Array} $0.getHeadComponents Returns the current `headComponents` array.
111 | * @param {function} $0.replaceHeadComponents Takes an array of components as its
112 | * first argument which replace the `headComponents` array which is passed
113 | * to the `html.js` component. **WARNING** if multiple plugins implement this
114 | * API it's the last plugin that "wins".
115 | * @param {Array} $0.getPreBodyComponents Returns the current `preBodyComponents` array.
116 | * @param {function} $0.replacePreBodyComponents Takes an array of components as its
117 | * first argument which replace the `preBodyComponents` array which is passed
118 | * to the `html.js` component. **WARNING** if multiple plugins implement this
119 | * API it's the last plugin that "wins".
120 | * @param {Array} $0.getPostBodyComponents Returns the current `postBodyComponents` array.
121 | * @param {function} $0.replacePostBodyComponents Takes an array of components as its
122 | * first argument which replace the `postBodyComponents` array which is passed
123 | * to the `html.js` component. **WARNING** if multiple plugins implement this
124 | * API it's the last plugin that "wins".
125 | * @param {pluginOptions} pluginOptions
126 | * @example
127 | * // Move Typography.js styles to the top of the head section so they're loaded first.
128 | * exports.onPreRenderHTML = ({ getHeadComponents, replaceHeadComponents }) => {
129 | * const headComponents = getHeadComponents()
130 | * headComponents.sort((x, y) => {
131 | * if (x.key === 'TypographyStyle') {
132 | * return -1
133 | * } else if (y.key === 'TypographyStyle') {
134 | * return 1
135 | * }
136 | * return 0
137 | * })
138 | * replaceHeadComponents(headComponents)
139 | * }
140 | */
141 |
142 | exports.onPreRenderHTML = true;
143 | /**
144 | * Allow a plugin to wrap the page element.
145 | *
146 | * This is useful for setting wrapper components around pages that won't get
147 | * unmounted on page changes. For setting Provider components, use [wrapRootElement](#wrapRootElement).
148 | *
149 | * _Note:_
150 | * There is an equivalent hook in Gatsby's [Browser API](/docs/browser-apis/#wrapPageElement).
151 | * It is recommended to use both APIs together.
152 | * For example usage, check out [Using i18n](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-i18n).
153 | * @param {object} $0
154 | * @param {ReactNode} $0.element The "Page" React Element built by Gatsby.
155 | * @param {object} $0.props Props object used by page.
156 | * @param {pluginOptions} pluginOptions
157 | * @returns {ReactNode} Wrapped element
158 | * @example
159 | * const React = require("react")
160 | * const Layout = require("./src/components/layout").default
161 | *
162 | * exports.wrapPageElement = ({ element, props }) => {
163 | * // props provide same data to Layout as Page element will get
164 | * // including location, data, etc - you don't need to pass it
165 | * return {element}
166 | * }
167 | */
168 |
169 | exports.wrapPageElement = true;
170 | /**
171 | * Allow a plugin to wrap the root element.
172 | *
173 | * This is useful to set up any Provider components that will wrap your application.
174 | * For setting persistent UI elements around pages use [wrapPageElement](#wrapPageElement).
175 | *
176 | * _Note:_
177 | * There is an equivalent hook in Gatsby's [Browser API](/docs/browser-apis/#wrapRootElement).
178 | * It is recommended to use both APIs together.
179 | * For example usage, check out [Using redux](https://github.com/gatsbyjs/gatsby/tree/master/examples/using-redux).
180 | * @param {object} $0
181 | * @param {ReactNode} $0.element The "Root" React Element built by Gatsby.
182 | * @param {pluginOptions} pluginOptions
183 | * @returns {ReactNode} Wrapped element
184 | * @example
185 | * const React = require("react")
186 | * const { Provider } = require("react-redux")
187 | *
188 | * const createStore = require("./src/state/createStore")
189 | * const store = createStore()
190 | *
191 | * exports.wrapRootElement = ({ element }) => {
192 | * return (
193 | *
194 | * {element}
195 | *
196 | * )
197 | * }
198 | */
199 |
200 | exports.wrapRootElement = true;
--------------------------------------------------------------------------------
/.cache/commonjs/app.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | var _react = _interopRequireDefault(require("react"));
6 |
7 | var _reactDom = _interopRequireDefault(require("react-dom"));
8 |
9 | var _domready = _interopRequireDefault(require("@mikaelkristiansson/domready"));
10 |
11 | var _socketIo = _interopRequireDefault(require("./socketIo"));
12 |
13 | var _emitter = _interopRequireDefault(require("./emitter"));
14 |
15 | var _apiRunnerBrowser = require("./api-runner-browser");
16 |
17 | var _loader = require("./loader");
18 |
19 | var _devLoader = _interopRequireDefault(require("./dev-loader"));
20 |
21 | var _syncRequires = _interopRequireDefault(require("./sync-requires"));
22 |
23 | var _matchPaths = _interopRequireDefault(require("./match-paths.json"));
24 |
25 | // Generated during bootstrap
26 | window.___emitter = _emitter.default;
27 | const loader = new _devLoader.default(_syncRequires.default, _matchPaths.default);
28 | (0, _loader.setLoader)(loader);
29 | loader.setApiRunner(_apiRunnerBrowser.apiRunner);
30 | window.___loader = _loader.publicLoader; // Let the site/plugins run code very early.
31 |
32 | (0, _apiRunnerBrowser.apiRunnerAsync)(`onClientEntry`).then(() => {
33 | // Hook up the client to socket.io on server
34 | const socket = (0, _socketIo.default)();
35 |
36 | if (socket) {
37 | socket.on(`reload`, () => {
38 | window.location.reload();
39 | });
40 | }
41 | /**
42 | * Service Workers are persistent by nature. They stick around,
43 | * serving a cached version of the site if they aren't removed.
44 | * This is especially frustrating when you need to test the
45 | * production build on your local machine.
46 | *
47 | * Let's warn if we find service workers in development.
48 | */
49 |
50 |
51 | if (`serviceWorker` in navigator) {
52 | navigator.serviceWorker.getRegistrations().then(registrations => {
53 | if (registrations.length > 0) console.warn(`Warning: found one or more service workers present.`, `If your site isn't behaving as expected, you might want to remove these.`, registrations);
54 | });
55 | }
56 |
57 | const rootElement = document.getElementById(`___gatsby`);
58 | const renderer = (0, _apiRunnerBrowser.apiRunner)(`replaceHydrateFunction`, undefined, _reactDom.default.render)[0];
59 | Promise.all([loader.loadPage(`/dev-404-page/`), loader.loadPage(`/404.html`), loader.loadPage(window.location.pathname)]).then(() => {
60 | const preferDefault = m => m && m.default || m;
61 |
62 | let Root = preferDefault(require(`./root`));
63 | (0, _domready.default)(() => {
64 | renderer( /*#__PURE__*/_react.default.createElement(Root, null), rootElement, () => {
65 | (0, _apiRunnerBrowser.apiRunner)(`onInitialClientRender`);
66 | });
67 | });
68 | });
69 | });
--------------------------------------------------------------------------------
/.cache/commonjs/create-react-context.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _react = _interopRequireDefault(require("react"));
9 |
10 | var _default = _react.default.createContext;
11 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/default-html.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = HTML;
7 |
8 | var _react = _interopRequireDefault(require("react"));
9 |
10 | var _propTypes = _interopRequireDefault(require("prop-types"));
11 |
12 | function HTML(props) {
13 | return (/*#__PURE__*/_react.default.createElement("html", props.htmlAttributes, /*#__PURE__*/_react.default.createElement("head", null, /*#__PURE__*/_react.default.createElement("meta", {
14 | charSet: "utf-8"
15 | }), /*#__PURE__*/_react.default.createElement("meta", {
16 | httpEquiv: "x-ua-compatible",
17 | content: "ie=edge"
18 | }), /*#__PURE__*/_react.default.createElement("meta", {
19 | name: "viewport",
20 | content: "width=device-width, initial-scale=1, shrink-to-fit=no"
21 | }), props.headComponents), /*#__PURE__*/_react.default.createElement("body", props.bodyAttributes, props.preBodyComponents, /*#__PURE__*/_react.default.createElement("div", {
22 | key: `body`,
23 | id: "___gatsby",
24 | dangerouslySetInnerHTML: {
25 | __html: props.body
26 | }
27 | }), props.postBodyComponents))
28 | );
29 | }
30 |
31 | HTML.propTypes = {
32 | htmlAttributes: _propTypes.default.object,
33 | headComponents: _propTypes.default.array,
34 | bodyAttributes: _propTypes.default.object,
35 | preBodyComponents: _propTypes.default.array,
36 | body: _propTypes.default.string,
37 | postBodyComponents: _propTypes.default.array
38 | };
--------------------------------------------------------------------------------
/.cache/commonjs/dev-loader.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.__esModule = true;
4 | exports.default = void 0;
5 |
6 | var _loader = require("./loader");
7 |
8 | var _findPath = require("./find-path");
9 |
10 | class DevLoader extends _loader.BaseLoader {
11 | constructor(syncRequires, matchPaths) {
12 | const loadComponent = chunkName => Promise.resolve(syncRequires.components[chunkName]);
13 |
14 | super(loadComponent, matchPaths);
15 | }
16 |
17 | loadPage(pagePath) {
18 | const realPath = (0, _findPath.findPath)(pagePath);
19 | return super.loadPage(realPath).then(result => require(`./socketIo`).getPageData(realPath).then(() => result));
20 | }
21 |
22 | loadPageDataJson(rawPath) {
23 | return super.loadPageDataJson(rawPath).then(data => {
24 | // when we can't find a proper 404.html we fallback to dev-404-page
25 | // we need to make sure to mark it as not found.
26 | if (data.status === _loader.PageResourceStatus.Error && rawPath !== `/dev-404-page/`) {
27 | console.error(`404 page could not be found. Checkout https://www.gatsbyjs.org/docs/add-404-page/`);
28 | return this.loadPageDataJson(`/dev-404-page/`).then(result => Object.assign({}, data, result));
29 | }
30 |
31 | return data;
32 | });
33 | }
34 |
35 | doPrefetch(pagePath) {
36 | return Promise.resolve(require(`./socketIo`).getPageData(pagePath));
37 | }
38 |
39 | }
40 |
41 | var _default = DevLoader;
42 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/develop-static-entry.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _react = _interopRequireDefault(require("react"));
9 |
10 | var _server = require("react-dom/server");
11 |
12 | var _lodash = require("lodash");
13 |
14 | var _apiRunnerSsr = _interopRequireDefault(require("./api-runner-ssr"));
15 |
16 | // import testRequireError from "./test-require-error"
17 | // For some extremely mysterious reason, webpack adds the above module *after*
18 | // this module so that when this code runs, testRequireError is undefined.
19 | // So in the meantime, we'll just inline it.
20 | const testRequireError = (moduleName, err) => {
21 | const regex = new RegExp(`Error: Cannot find module\\s.${moduleName}`);
22 | const firstLine = err.toString().split(`\n`)[0];
23 | return regex.test(firstLine);
24 | };
25 |
26 | let Html;
27 |
28 | try {
29 | Html = require(`../src/html`);
30 | } catch (err) {
31 | if (testRequireError(`../src/html`, err)) {
32 | Html = require(`./default-html`);
33 | } else {
34 | console.log(`There was an error requiring "src/html.js"\n\n`, err, `\n\n`);
35 | process.exit();
36 | }
37 | }
38 |
39 | Html = Html && Html.__esModule ? Html.default : Html;
40 |
41 | var _default = (pagePath, callback) => {
42 | let headComponents = [/*#__PURE__*/_react.default.createElement("meta", {
43 | key: "environment",
44 | name: "note",
45 | content: "environment=development"
46 | })];
47 | let htmlAttributes = {};
48 | let bodyAttributes = {};
49 | let preBodyComponents = [];
50 | let postBodyComponents = [];
51 | let bodyProps = {};
52 | let htmlStr;
53 |
54 | const setHeadComponents = components => {
55 | headComponents = headComponents.concat(components);
56 | };
57 |
58 | const setHtmlAttributes = attributes => {
59 | htmlAttributes = (0, _lodash.merge)(htmlAttributes, attributes);
60 | };
61 |
62 | const setBodyAttributes = attributes => {
63 | bodyAttributes = (0, _lodash.merge)(bodyAttributes, attributes);
64 | };
65 |
66 | const setPreBodyComponents = components => {
67 | preBodyComponents = preBodyComponents.concat(components);
68 | };
69 |
70 | const setPostBodyComponents = components => {
71 | postBodyComponents = postBodyComponents.concat(components);
72 | };
73 |
74 | const setBodyProps = props => {
75 | bodyProps = (0, _lodash.merge)({}, bodyProps, props);
76 | };
77 |
78 | const getHeadComponents = () => headComponents;
79 |
80 | const replaceHeadComponents = components => {
81 | headComponents = components;
82 | };
83 |
84 | const getPreBodyComponents = () => preBodyComponents;
85 |
86 | const replacePreBodyComponents = components => {
87 | preBodyComponents = components;
88 | };
89 |
90 | const getPostBodyComponents = () => postBodyComponents;
91 |
92 | const replacePostBodyComponents = components => {
93 | postBodyComponents = components;
94 | };
95 |
96 | (0, _apiRunnerSsr.default)(`onRenderBody`, {
97 | setHeadComponents,
98 | setHtmlAttributes,
99 | setBodyAttributes,
100 | setPreBodyComponents,
101 | setPostBodyComponents,
102 | setBodyProps,
103 | pathname: pagePath
104 | });
105 | (0, _apiRunnerSsr.default)(`onPreRenderHTML`, {
106 | getHeadComponents,
107 | replaceHeadComponents,
108 | getPreBodyComponents,
109 | replacePreBodyComponents,
110 | getPostBodyComponents,
111 | replacePostBodyComponents,
112 | pathname: pagePath
113 | });
114 |
115 | const htmlElement = _react.default.createElement(Html, { ...bodyProps,
116 | body: ``,
117 | headComponents: headComponents.concat([/*#__PURE__*/_react.default.createElement("script", {
118 | key: `io`,
119 | src: "/socket.io/socket.io.js"
120 | })]),
121 | htmlAttributes,
122 | bodyAttributes,
123 | preBodyComponents,
124 | postBodyComponents: postBodyComponents.concat([/*#__PURE__*/_react.default.createElement("script", {
125 | key: `commons`,
126 | src: "/commons.js"
127 | })])
128 | });
129 |
130 | htmlStr = (0, _server.renderToStaticMarkup)(htmlElement);
131 | htmlStr = `${htmlStr}`;
132 | callback(null, htmlStr);
133 | };
134 |
135 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/emitter.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _mitt = _interopRequireDefault(require("mitt"));
9 |
10 | const emitter = (0, _mitt.default)();
11 | var _default = emitter;
12 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/ensure-resources.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4 |
5 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6 |
7 | exports.__esModule = true;
8 | exports.default = void 0;
9 |
10 | var _react = _interopRequireDefault(require("react"));
11 |
12 | var _loader = _interopRequireWildcard(require("./loader"));
13 |
14 | var _shallowCompare = _interopRequireDefault(require("shallow-compare"));
15 |
16 | class EnsureResources extends _react.default.Component {
17 | constructor(props) {
18 | super();
19 | const {
20 | location,
21 | pageResources
22 | } = props;
23 | this.state = {
24 | location: { ...location
25 | },
26 | pageResources: pageResources || _loader.default.loadPageSync(location.pathname)
27 | };
28 | }
29 |
30 | static getDerivedStateFromProps({
31 | location
32 | }, prevState) {
33 | if (prevState.location.href !== location.href) {
34 | const pageResources = _loader.default.loadPageSync(location.pathname);
35 |
36 | return {
37 | pageResources,
38 | location: { ...location
39 | }
40 | };
41 | }
42 |
43 | return {
44 | location: { ...location
45 | }
46 | };
47 | }
48 |
49 | loadResources(rawPath) {
50 | _loader.default.loadPage(rawPath).then(pageResources => {
51 | if (pageResources && pageResources.status !== _loader.PageResourceStatus.Error) {
52 | this.setState({
53 | location: { ...window.location
54 | },
55 | pageResources
56 | });
57 | } else {
58 | window.history.replaceState({}, ``, location.href);
59 | window.location = rawPath;
60 | }
61 | });
62 | }
63 |
64 | shouldComponentUpdate(nextProps, nextState) {
65 | // Always return false if we're missing resources.
66 | if (!nextState.pageResources) {
67 | this.loadResources(nextProps.location.pathname);
68 | return false;
69 | } // Check if the component or json have changed.
70 |
71 |
72 | if (this.state.pageResources !== nextState.pageResources) {
73 | return true;
74 | }
75 |
76 | if (this.state.pageResources.component !== nextState.pageResources.component) {
77 | return true;
78 | }
79 |
80 | if (this.state.pageResources.json !== nextState.pageResources.json) {
81 | return true;
82 | } // Check if location has changed on a page using internal routing
83 | // via matchPath configuration.
84 |
85 |
86 | if (this.state.location.key !== nextState.location.key && nextState.pageResources.page && (nextState.pageResources.page.matchPath || nextState.pageResources.page.path)) {
87 | return true;
88 | }
89 |
90 | return (0, _shallowCompare.default)(this, nextProps, nextState);
91 | }
92 |
93 | render() {
94 | if (process.env.NODE_ENV !== `production` && !this.state.pageResources) {
95 | throw new Error(`EnsureResources was not able to find resources for path: "${this.props.location.pathname}"
96 | This typically means that an issue occurred building components for that path.
97 | Run \`gatsby clean\` to remove any cached elements.`);
98 | }
99 |
100 | return this.props.children(this.state);
101 | }
102 |
103 | }
104 |
105 | var _default = EnsureResources;
106 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/error-overlay-handler.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4 |
5 | exports.__esModule = true;
6 | exports.errorMap = exports.reportError = exports.clearError = void 0;
7 |
8 | var ReactRefreshErrorOverlay = _interopRequireWildcard(require("@pmmmwh/react-refresh-webpack-plugin/src/overlay"));
9 |
10 | var ReactErrorOverlay = _interopRequireWildcard(require("react-error-overlay"));
11 |
12 | const ErrorOverlay = {
13 | showCompileError: process.env.GATSBY_HOT_LOADER !== `fast-refresh` ? ReactErrorOverlay.reportBuildError : ReactRefreshErrorOverlay.showCompileError,
14 | clearCompileError: process.env.GATSBY_HOT_LOADER !== `fast-refresh` ? ReactErrorOverlay.dismissBuildError : ReactRefreshErrorOverlay.clearCompileError
15 | };
16 |
17 | if (process.env.GATSBY_HOT_LOADER !== `fast-refresh`) {
18 | // Report runtime errors
19 | ReactErrorOverlay.startReportingRuntimeErrors({
20 | onError: () => {},
21 | filename: `/commons.js`
22 | });
23 | ReactErrorOverlay.setEditorHandler(errorLocation => window.fetch(`/__open-stack-frame-in-editor?fileName=` + window.encodeURIComponent(errorLocation.fileName) + `&lineNumber=` + window.encodeURIComponent(errorLocation.lineNumber || 1)));
24 | }
25 |
26 | const errorMap = {};
27 | exports.errorMap = errorMap;
28 |
29 | function flat(arr) {
30 | return Array.prototype.flat ? arr.flat() : [].concat(...arr);
31 | }
32 |
33 | const handleErrorOverlay = () => {
34 | const errors = Object.values(errorMap);
35 | let errorStringsToDisplay = [];
36 |
37 | if (errors.length > 0) {
38 | errorStringsToDisplay = flat(errors).map(error => {
39 | if (typeof error === `string`) {
40 | return error;
41 | } else if (typeof error === `object`) {
42 | const errorStrBuilder = [error.text];
43 |
44 | if (error.filePath) {
45 | errorStrBuilder.push(`File: ${error.filePath}`);
46 | }
47 |
48 | return errorStrBuilder.join(`\n\n`);
49 | }
50 |
51 | return null;
52 | }).filter(Boolean);
53 | }
54 |
55 | if (errorStringsToDisplay.length > 0) {
56 | ErrorOverlay.showCompileError(errorStringsToDisplay.join(`\n\n`));
57 | } else {
58 | ErrorOverlay.clearCompileError();
59 | }
60 | };
61 |
62 | const clearError = errorID => {
63 | delete errorMap[errorID];
64 | handleErrorOverlay();
65 | };
66 |
67 | exports.clearError = clearError;
68 |
69 | const reportError = (errorID, error) => {
70 | if (error) {
71 | errorMap[errorID] = error;
72 | }
73 |
74 | handleErrorOverlay();
75 | };
76 |
77 | exports.reportError = reportError;
--------------------------------------------------------------------------------
/.cache/commonjs/find-path.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.cleanPath = exports.findPath = exports.findMatchPath = exports.setMatchPaths = void 0;
7 |
8 | var _utils = require("@reach/router/lib/utils");
9 |
10 | var _stripPrefix = _interopRequireDefault(require("./strip-prefix"));
11 |
12 | var _normalizePagePath = _interopRequireDefault(require("./normalize-page-path"));
13 |
14 | const pathCache = new Map();
15 | let matchPaths = [];
16 |
17 | const trimPathname = rawPathname => {
18 | const pathname = decodeURIComponent(rawPathname); // Remove the pathPrefix from the pathname.
19 |
20 | const trimmedPathname = (0, _stripPrefix.default)(pathname, __BASE_PATH__) // Remove any hashfragment
21 | .split(`#`)[0] // Remove search query
22 | .split(`?`)[0];
23 | return trimmedPathname;
24 | };
25 | /**
26 | * Set list of matchPaths
27 | *
28 | * @param {Array<{path: string, matchPath: string}>} value collection of matchPaths
29 | */
30 |
31 |
32 | const setMatchPaths = value => {
33 | matchPaths = value;
34 | };
35 | /**
36 | * Return a matchpath url
37 | * if `match-paths.json` contains `{ "/foo*": "/page1", ...}`, then
38 | * `/foo?bar=far` => `/page1`
39 | *
40 | * @param {string} rawPathname A raw pathname
41 | * @return {string|null}
42 | */
43 |
44 |
45 | exports.setMatchPaths = setMatchPaths;
46 |
47 | const findMatchPath = rawPathname => {
48 | const trimmedPathname = cleanPath(rawPathname);
49 |
50 | for (const {
51 | matchPath,
52 | path
53 | } of matchPaths) {
54 | if ((0, _utils.match)(matchPath, trimmedPathname)) {
55 | return (0, _normalizePagePath.default)(path);
56 | }
57 | }
58 |
59 | return null;
60 | }; // Given a raw URL path, returns the cleaned version of it (trim off
61 | // `#` and query params), or if it matches an entry in
62 | // `match-paths.json`, its matched path is returned
63 | //
64 | // E.g. `/foo?bar=far` => `/foo`
65 | //
66 | // Or if `match-paths.json` contains `{ "/foo*": "/page1", ...}`, then
67 | // `/foo?bar=far` => `/page1`
68 |
69 |
70 | exports.findMatchPath = findMatchPath;
71 |
72 | const findPath = rawPathname => {
73 | const trimmedPathname = trimPathname(rawPathname);
74 |
75 | if (pathCache.has(trimmedPathname)) {
76 | return pathCache.get(trimmedPathname);
77 | }
78 |
79 | let foundPath = findMatchPath(trimmedPathname);
80 |
81 | if (!foundPath) {
82 | foundPath = cleanPath(rawPathname);
83 | }
84 |
85 | pathCache.set(trimmedPathname, foundPath);
86 | return foundPath;
87 | };
88 | /**
89 | * Clean a url and converts /index.html => /
90 | * E.g. `/foo?bar=far` => `/foo`
91 | *
92 | * @param {string} rawPathname A raw pathname
93 | * @return {string}
94 | */
95 |
96 |
97 | exports.findPath = findPath;
98 |
99 | const cleanPath = rawPathname => {
100 | const trimmedPathname = trimPathname(rawPathname);
101 | let foundPath = trimmedPathname;
102 |
103 | if (foundPath === `/index.html`) {
104 | foundPath = `/`;
105 | }
106 |
107 | foundPath = (0, _normalizePagePath.default)(foundPath);
108 | return foundPath;
109 | };
110 |
111 | exports.cleanPath = cleanPath;
--------------------------------------------------------------------------------
/.cache/commonjs/gatsby-browser-entry.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4 |
5 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6 |
7 | exports.__esModule = true;
8 | exports.graphql = graphql;
9 | exports.prefetchPathname = exports.useStaticQuery = exports.StaticQuery = exports.StaticQueryContext = void 0;
10 |
11 | var _react = _interopRequireDefault(require("react"));
12 |
13 | var _propTypes = _interopRequireDefault(require("prop-types"));
14 |
15 | var _gatsbyLink = _interopRequireWildcard(require("gatsby-link"));
16 |
17 | exports.Link = _gatsbyLink.default;
18 | exports.withPrefix = _gatsbyLink.withPrefix;
19 | exports.withAssetPrefix = _gatsbyLink.withAssetPrefix;
20 | exports.navigate = _gatsbyLink.navigate;
21 | exports.push = _gatsbyLink.push;
22 | exports.replace = _gatsbyLink.replace;
23 | exports.navigateTo = _gatsbyLink.navigateTo;
24 | exports.parsePath = _gatsbyLink.parsePath;
25 |
26 | var _publicPageRenderer = _interopRequireDefault(require("./public-page-renderer"));
27 |
28 | exports.PageRenderer = _publicPageRenderer.default;
29 |
30 | var _loader = _interopRequireDefault(require("./loader"));
31 |
32 | const prefetchPathname = _loader.default.enqueue;
33 | exports.prefetchPathname = prefetchPathname;
34 |
35 | const StaticQueryContext = _react.default.createContext({});
36 |
37 | exports.StaticQueryContext = StaticQueryContext;
38 |
39 | function StaticQueryDataRenderer({
40 | staticQueryData,
41 | data,
42 | query,
43 | render
44 | }) {
45 | const finalData = data ? data.data : staticQueryData[query] && staticQueryData[query].data;
46 | return (/*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, finalData && render(finalData), !finalData && /*#__PURE__*/_react.default.createElement("div", null, "Loading (StaticQuery)"))
47 | );
48 | }
49 |
50 | const StaticQuery = props => {
51 | const {
52 | data,
53 | query,
54 | render,
55 | children
56 | } = props;
57 | return (/*#__PURE__*/_react.default.createElement(StaticQueryContext.Consumer, null, staticQueryData => /*#__PURE__*/_react.default.createElement(StaticQueryDataRenderer, {
58 | data: data,
59 | query: query,
60 | render: render || children,
61 | staticQueryData: staticQueryData
62 | }))
63 | );
64 | };
65 |
66 | exports.StaticQuery = StaticQuery;
67 |
68 | const useStaticQuery = query => {
69 | if (typeof _react.default.useContext !== `function` && process.env.NODE_ENV === `development`) {
70 | throw new Error(`You're likely using a version of React that doesn't support Hooks\n` + `Please update React and ReactDOM to 16.8.0 or later to use the useStaticQuery hook.`);
71 | }
72 |
73 | const context = _react.default.useContext(StaticQueryContext); // query is a stringified number like `3303882` when wrapped with graphql, If a user forgets
74 | // to wrap the query in a grqphql, then casting it to a Number results in `NaN` allowing us to
75 | // catch the misuse of the API and give proper direction
76 |
77 |
78 | if (isNaN(Number(query))) {
79 | throw new Error(`useStaticQuery was called with a string but expects to be called using \`graphql\`. Try this:
80 |
81 | import { useStaticQuery, graphql } from 'gatsby';
82 |
83 | useStaticQuery(graphql\`${query}\`);
84 | `);
85 | }
86 |
87 | if (context[query] && context[query].data) {
88 | return context[query].data;
89 | } else {
90 | throw new Error(`The result of this StaticQuery could not be fetched.\n\n` + `This is likely a bug in Gatsby and if refreshing the page does not fix it, ` + `please open an issue in https://github.com/gatsbyjs/gatsby/issues`);
91 | }
92 | };
93 |
94 | exports.useStaticQuery = useStaticQuery;
95 | StaticQuery.propTypes = {
96 | data: _propTypes.default.object,
97 | query: _propTypes.default.string.isRequired,
98 | render: _propTypes.default.func,
99 | children: _propTypes.default.func
100 | };
101 |
102 | function graphql() {
103 | throw new Error(`It appears like Gatsby is misconfigured. Gatsby related \`graphql\` calls ` + `are supposed to only be evaluated at compile time, and then compiled away. ` + `Unfortunately, something went wrong and the query was left in the compiled code.\n\n` + `Unless your site has a complex or custom babel/Gatsby configuration this is likely a bug in Gatsby.`);
104 | }
--------------------------------------------------------------------------------
/.cache/commonjs/navigation.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4 |
5 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6 |
7 | exports.__esModule = true;
8 | exports.init = init;
9 | exports.shouldUpdateScroll = shouldUpdateScroll;
10 | exports.RouteUpdates = void 0;
11 |
12 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13 |
14 | var _react = _interopRequireDefault(require("react"));
15 |
16 | var _propTypes = _interopRequireDefault(require("prop-types"));
17 |
18 | var _loader = _interopRequireWildcard(require("./loader"));
19 |
20 | var _redirects = _interopRequireDefault(require("./redirects.json"));
21 |
22 | var _apiRunnerBrowser = require("./api-runner-browser");
23 |
24 | var _emitter = _interopRequireDefault(require("./emitter"));
25 |
26 | var _routeAnnouncerProps = require("./route-announcer-props");
27 |
28 | var _router = require("@reach/router");
29 |
30 | var _history = require("@reach/router/lib/history");
31 |
32 | var _gatsbyLink = require("gatsby-link");
33 |
34 | // Convert to a map for faster lookup in maybeRedirect()
35 | const redirectMap = _redirects.default.reduce((map, redirect) => {
36 | map[redirect.fromPath] = redirect;
37 | return map;
38 | }, {});
39 |
40 | function maybeRedirect(pathname) {
41 | const redirect = redirectMap[pathname];
42 |
43 | if (redirect != null) {
44 | if (process.env.NODE_ENV !== `production`) {
45 | if (!_loader.default.isPageNotFound(pathname)) {
46 | console.error(`The route "${pathname}" matches both a page and a redirect; this is probably not intentional.`);
47 | }
48 | }
49 |
50 | window.___replace(redirect.toPath);
51 |
52 | return true;
53 | } else {
54 | return false;
55 | }
56 | }
57 |
58 | const onPreRouteUpdate = (location, prevLocation) => {
59 | if (!maybeRedirect(location.pathname)) {
60 | (0, _apiRunnerBrowser.apiRunner)(`onPreRouteUpdate`, {
61 | location,
62 | prevLocation
63 | });
64 | }
65 | };
66 |
67 | const onRouteUpdate = (location, prevLocation) => {
68 | if (!maybeRedirect(location.pathname)) {
69 | (0, _apiRunnerBrowser.apiRunner)(`onRouteUpdate`, {
70 | location,
71 | prevLocation
72 | });
73 | }
74 | };
75 |
76 | const navigate = (to, options = {}) => {
77 | let {
78 | pathname
79 | } = (0, _gatsbyLink.parsePath)(to);
80 | const redirect = redirectMap[pathname]; // If we're redirecting, just replace the passed in pathname
81 | // to the one we want to redirect to.
82 |
83 | if (redirect) {
84 | to = redirect.toPath;
85 | pathname = (0, _gatsbyLink.parsePath)(to).pathname;
86 | } // If we had a service worker update, no matter the path, reload window and
87 | // reset the pathname whitelist
88 |
89 |
90 | if (window.___swUpdated) {
91 | window.location = pathname;
92 | return;
93 | } // Start a timer to wait for a second before transitioning and showing a
94 | // loader in case resources aren't around yet.
95 |
96 |
97 | const timeoutId = setTimeout(() => {
98 | _emitter.default.emit(`onDelayedLoadPageResources`, {
99 | pathname
100 | });
101 |
102 | (0, _apiRunnerBrowser.apiRunner)(`onRouteUpdateDelayed`, {
103 | location: window.location
104 | });
105 | }, 1000);
106 |
107 | _loader.default.loadPage(pathname).then(pageResources => {
108 | // If no page resources, then refresh the page
109 | // Do this, rather than simply `window.location.reload()`, so that
110 | // pressing the back/forward buttons work - otherwise when pressing
111 | // back, the browser will just change the URL and expect JS to handle
112 | // the change, which won't always work since it might not be a Gatsby
113 | // page.
114 | if (!pageResources || pageResources.status === _loader.PageResourceStatus.Error) {
115 | window.history.replaceState({}, ``, location.href);
116 | window.location = pathname;
117 | clearTimeout(timeoutId);
118 | return;
119 | } // If the loaded page has a different compilation hash to the
120 | // window, then a rebuild has occurred on the server. Reload.
121 |
122 |
123 | if (process.env.NODE_ENV === `production` && pageResources) {
124 | if (pageResources.page.webpackCompilationHash !== window.___webpackCompilationHash) {
125 | // Purge plugin-offline cache
126 | if (`serviceWorker` in navigator && navigator.serviceWorker.controller !== null && navigator.serviceWorker.controller.state === `activated`) {
127 | navigator.serviceWorker.controller.postMessage({
128 | gatsbyApi: `clearPathResources`
129 | });
130 | }
131 |
132 | console.log(`Site has changed on server. Reloading browser`);
133 | window.location = pathname;
134 | }
135 | }
136 |
137 | (0, _router.navigate)(to, options);
138 | clearTimeout(timeoutId);
139 | });
140 | };
141 |
142 | function shouldUpdateScroll(prevRouterProps, {
143 | location
144 | }) {
145 | const {
146 | pathname,
147 | hash
148 | } = location;
149 | const results = (0, _apiRunnerBrowser.apiRunner)(`shouldUpdateScroll`, {
150 | prevRouterProps,
151 | // `pathname` for backwards compatibility
152 | pathname,
153 | routerProps: {
154 | location
155 | },
156 | getSavedScrollPosition: args => this._stateStorage.read(args)
157 | });
158 |
159 | if (results.length > 0) {
160 | // Use the latest registered shouldUpdateScroll result, this allows users to override plugin's configuration
161 | // @see https://github.com/gatsbyjs/gatsby/issues/12038
162 | return results[results.length - 1];
163 | }
164 |
165 | if (prevRouterProps) {
166 | const {
167 | location: {
168 | pathname: oldPathname
169 | }
170 | } = prevRouterProps;
171 |
172 | if (oldPathname === pathname) {
173 | // Scroll to element if it exists, if it doesn't, or no hash is provided,
174 | // scroll to top.
175 | return hash ? decodeURI(hash.slice(1)) : [0, 0];
176 | }
177 | }
178 |
179 | return true;
180 | }
181 |
182 | function init() {
183 | // The "scroll-behavior" package expects the "action" to be on the location
184 | // object so let's copy it over.
185 | _history.globalHistory.listen(args => {
186 | args.location.action = args.action;
187 | });
188 |
189 | window.___push = to => navigate(to, {
190 | replace: false
191 | });
192 |
193 | window.___replace = to => navigate(to, {
194 | replace: true
195 | });
196 |
197 | window.___navigate = (to, options) => navigate(to, options); // Check for initial page-load redirect
198 |
199 |
200 | maybeRedirect(window.location.pathname);
201 | }
202 |
203 | class RouteAnnouncer extends _react.default.Component {
204 | constructor(props) {
205 | super(props);
206 | this.announcementRef = _react.default.createRef();
207 | }
208 |
209 | componentDidUpdate(prevProps, nextProps) {
210 | requestAnimationFrame(() => {
211 | let pageName = `new page at ${this.props.location.pathname}`;
212 |
213 | if (document.title) {
214 | pageName = document.title;
215 | }
216 |
217 | const pageHeadings = document.querySelectorAll(`#gatsby-focus-wrapper h1`);
218 |
219 | if (pageHeadings && pageHeadings.length) {
220 | pageName = pageHeadings[0].textContent;
221 | }
222 |
223 | const newAnnouncement = `Navigated to ${pageName}`;
224 | const oldAnnouncement = this.announcementRef.current.innerText;
225 |
226 | if (oldAnnouncement !== newAnnouncement) {
227 | this.announcementRef.current.innerText = newAnnouncement;
228 | }
229 | });
230 | }
231 |
232 | render() {
233 | return (/*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({}, _routeAnnouncerProps.RouteAnnouncerProps, {
234 | ref: this.announcementRef
235 | }))
236 | );
237 | }
238 |
239 | } // Fire on(Pre)RouteUpdate APIs
240 |
241 |
242 | class RouteUpdates extends _react.default.Component {
243 | constructor(props) {
244 | super(props);
245 | onPreRouteUpdate(props.location, null);
246 | }
247 |
248 | componentDidMount() {
249 | onRouteUpdate(this.props.location, null);
250 | }
251 |
252 | componentDidUpdate(prevProps, prevState, shouldFireRouteUpdate) {
253 | if (shouldFireRouteUpdate) {
254 | onRouteUpdate(this.props.location, prevProps.location);
255 | }
256 | }
257 |
258 | getSnapshotBeforeUpdate(prevProps) {
259 | if (this.props.location.pathname !== prevProps.location.pathname) {
260 | onPreRouteUpdate(this.props.location, prevProps.location);
261 | return true;
262 | }
263 |
264 | return false;
265 | }
266 |
267 | render() {
268 | return (/*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, this.props.children, /*#__PURE__*/_react.default.createElement(RouteAnnouncer, {
269 | location: location
270 | }))
271 | );
272 | }
273 |
274 | }
275 |
276 | exports.RouteUpdates = RouteUpdates;
277 | RouteUpdates.propTypes = {
278 | location: _propTypes.default.object.isRequired
279 | };
--------------------------------------------------------------------------------
/.cache/commonjs/normalize-page-path.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.__esModule = true;
4 | exports.default = void 0;
5 |
6 | var _default = path => {
7 | if (path === undefined) {
8 | return path;
9 | }
10 |
11 | if (path === `/`) {
12 | return `/`;
13 | }
14 |
15 | if (path.charAt(path.length - 1) === `/`) {
16 | return path.slice(0, -1);
17 | }
18 |
19 | return path;
20 | };
21 |
22 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/page-renderer.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
6 |
7 | exports.__esModule = true;
8 | exports.default = void 0;
9 |
10 | var _react = _interopRequireWildcard(require("react"));
11 |
12 | var _propTypes = _interopRequireDefault(require("prop-types"));
13 |
14 | var _loader = require("./loader");
15 |
16 | var _apiRunnerBrowser = require("./api-runner-browser");
17 |
18 | // Renders page
19 | class PageRenderer extends _react.default.Component {
20 | render() {
21 | const props = { ...this.props,
22 | pathContext: this.props.pageContext
23 | };
24 | const [replacementElement] = (0, _apiRunnerBrowser.apiRunner)(`replaceComponentRenderer`, {
25 | props: this.props,
26 | loader: _loader.publicLoader
27 | });
28 | const pageElement = replacementElement || (0, _react.createElement)(this.props.pageResources.component, { ...props,
29 | key: this.props.path || this.props.pageResources.page.path
30 | });
31 | const wrappedPage = (0, _apiRunnerBrowser.apiRunner)(`wrapPageElement`, {
32 | element: pageElement,
33 | props
34 | }, pageElement, ({
35 | result
36 | }) => {
37 | return {
38 | element: result,
39 | props
40 | };
41 | }).pop();
42 | return wrappedPage;
43 | }
44 |
45 | }
46 |
47 | PageRenderer.propTypes = {
48 | location: _propTypes.default.object.isRequired,
49 | pageResources: _propTypes.default.object.isRequired,
50 | data: _propTypes.default.object,
51 | pageContext: _propTypes.default.object.isRequired
52 | };
53 | var _default = PageRenderer;
54 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/prefetch.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.__esModule = true;
4 | exports.default = void 0;
5 |
6 | const support = function (feature) {
7 | if (typeof document === `undefined`) {
8 | return false;
9 | }
10 |
11 | const fakeLink = document.createElement(`link`);
12 |
13 | try {
14 | if (fakeLink.relList && typeof fakeLink.relList.supports === `function`) {
15 | return fakeLink.relList.supports(feature);
16 | }
17 | } catch (err) {
18 | return false;
19 | }
20 |
21 | return false;
22 | };
23 |
24 | const linkPrefetchStrategy = function (url, options) {
25 | return new Promise((resolve, reject) => {
26 | if (typeof document === `undefined`) {
27 | reject();
28 | return;
29 | }
30 |
31 | const link = document.createElement(`link`);
32 | link.setAttribute(`rel`, `prefetch`);
33 | link.setAttribute(`href`, url);
34 | Object.keys(options).forEach(key => {
35 | link.setAttribute(key, options[key]);
36 | });
37 | link.onload = resolve;
38 | link.onerror = reject;
39 | const parentElement = document.getElementsByTagName(`head`)[0] || document.getElementsByName(`script`)[0].parentNode;
40 | parentElement.appendChild(link);
41 | });
42 | };
43 |
44 | const xhrPrefetchStrategy = function (url) {
45 | return new Promise((resolve, reject) => {
46 | const req = new XMLHttpRequest();
47 | req.open(`GET`, url, true);
48 |
49 | req.onload = () => {
50 | if (req.status === 200) {
51 | resolve();
52 | } else {
53 | reject();
54 | }
55 | };
56 |
57 | req.send(null);
58 | });
59 | };
60 |
61 | const supportedPrefetchStrategy = support(`prefetch`) ? linkPrefetchStrategy : xhrPrefetchStrategy;
62 | const preFetched = {};
63 |
64 | const prefetch = function (url, options) {
65 | return new Promise(resolve => {
66 | if (preFetched[url]) {
67 | resolve();
68 | return;
69 | }
70 |
71 | supportedPrefetchStrategy(url, options).then(() => {
72 | resolve();
73 | preFetched[url] = true;
74 | }).catch(() => {}); // 404s are logged to the console anyway
75 | });
76 | };
77 |
78 | var _default = prefetch;
79 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/production-app.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
6 |
7 | var _apiRunnerBrowser = require("./api-runner-browser");
8 |
9 | var _react = _interopRequireDefault(require("react"));
10 |
11 | var _reactDom = _interopRequireDefault(require("react-dom"));
12 |
13 | var _router = require("@reach/router");
14 |
15 | var _gatsbyReactRouterScroll = require("gatsby-react-router-scroll");
16 |
17 | var _domready = _interopRequireDefault(require("@mikaelkristiansson/domready"));
18 |
19 | var _navigation = require("./navigation");
20 |
21 | var _emitter = _interopRequireDefault(require("./emitter"));
22 |
23 | var _pageRenderer = _interopRequireDefault(require("./page-renderer"));
24 |
25 | var _asyncRequires = _interopRequireDefault(require("./async-requires"));
26 |
27 | var _loader = require("./loader");
28 |
29 | var _ensureResources = _interopRequireDefault(require("./ensure-resources"));
30 |
31 | var _stripPrefix = _interopRequireDefault(require("./strip-prefix"));
32 |
33 | var _matchPaths = _interopRequireDefault(require("./match-paths.json"));
34 |
35 | // Generated during bootstrap
36 | const loader = new _loader.ProdLoader(_asyncRequires.default, _matchPaths.default);
37 | (0, _loader.setLoader)(loader);
38 | loader.setApiRunner(_apiRunnerBrowser.apiRunner);
39 | window.asyncRequires = _asyncRequires.default;
40 | window.___emitter = _emitter.default;
41 | window.___loader = _loader.publicLoader;
42 | (0, _navigation.init)();
43 | (0, _apiRunnerBrowser.apiRunnerAsync)(`onClientEntry`).then(() => {
44 | // Let plugins register a service worker. The plugin just needs
45 | // to return true.
46 | if ((0, _apiRunnerBrowser.apiRunner)(`registerServiceWorker`).length > 0) {
47 | require(`./register-service-worker`);
48 | } // In gatsby v2 if Router is used in page using matchPaths
49 | // paths need to contain full path.
50 | // For example:
51 | // - page have `/app/*` matchPath
52 | // - inside template user needs to use `/app/xyz` as path
53 | // Resetting `basepath`/`baseuri` keeps current behaviour
54 | // to not introduce breaking change.
55 | // Remove this in v3
56 |
57 |
58 | const RouteHandler = props => /*#__PURE__*/_react.default.createElement(_router.BaseContext.Provider, {
59 | value: {
60 | baseuri: `/`,
61 | basepath: `/`
62 | }
63 | }, /*#__PURE__*/_react.default.createElement(_pageRenderer.default, props));
64 |
65 | class LocationHandler extends _react.default.Component {
66 | render() {
67 | const {
68 | location
69 | } = this.props;
70 | return (/*#__PURE__*/_react.default.createElement(_ensureResources.default, {
71 | location: location
72 | }, ({
73 | pageResources,
74 | location
75 | }) => /*#__PURE__*/_react.default.createElement(_navigation.RouteUpdates, {
76 | location: location
77 | }, /*#__PURE__*/_react.default.createElement(_gatsbyReactRouterScroll.ScrollContext, {
78 | location: location,
79 | shouldUpdateScroll: _navigation.shouldUpdateScroll
80 | }, /*#__PURE__*/_react.default.createElement(_router.Router, {
81 | basepath: __BASE_PATH__,
82 | location: location,
83 | id: "gatsby-focus-wrapper"
84 | }, /*#__PURE__*/_react.default.createElement(RouteHandler, (0, _extends2.default)({
85 | path: pageResources.page.path === `/404.html` ? (0, _stripPrefix.default)(location.pathname, __BASE_PATH__) : encodeURI(pageResources.page.matchPath || pageResources.page.path)
86 | }, this.props, {
87 | location: location,
88 | pageResources: pageResources
89 | }, pageResources.json))))))
90 | );
91 | }
92 |
93 | }
94 |
95 | const {
96 | pagePath,
97 | location: browserLoc
98 | } = window; // Explicitly call navigate if the canonical path (window.pagePath)
99 | // is different to the browser path (window.location.pathname). But
100 | // only if NONE of the following conditions hold:
101 | //
102 | // - The url matches a client side route (page.matchPath)
103 | // - it's a 404 page
104 | // - it's the offline plugin shell (/offline-plugin-app-shell-fallback/)
105 |
106 | if (pagePath && __BASE_PATH__ + pagePath !== browserLoc.pathname && !(loader.findMatchPath((0, _stripPrefix.default)(browserLoc.pathname, __BASE_PATH__)) || pagePath === `/404.html` || pagePath.match(/^\/404\/?$/) || pagePath.match(/^\/offline-plugin-app-shell-fallback\/?$/))) {
107 | (0, _router.navigate)(__BASE_PATH__ + pagePath + browserLoc.search + browserLoc.hash, {
108 | replace: true
109 | });
110 | }
111 |
112 | _loader.publicLoader.loadPage(browserLoc.pathname).then(page => {
113 | if (!page || page.status === _loader.PageResourceStatus.Error) {
114 | throw new Error(`page resources for ${browserLoc.pathname} not found. Not rendering React`);
115 | }
116 |
117 | window.___webpackCompilationHash = page.page.webpackCompilationHash;
118 |
119 | const Root = () => /*#__PURE__*/_react.default.createElement(_router.Location, null, locationContext => /*#__PURE__*/_react.default.createElement(LocationHandler, locationContext));
120 |
121 | const WrappedRoot = (0, _apiRunnerBrowser.apiRunner)(`wrapRootElement`, {
122 | element: /*#__PURE__*/_react.default.createElement(Root, null)
123 | }, /*#__PURE__*/_react.default.createElement(Root, null), ({
124 | result
125 | }) => {
126 | return {
127 | element: result
128 | };
129 | }).pop();
130 |
131 | const NewRoot = () => WrappedRoot;
132 |
133 | const renderer = (0, _apiRunnerBrowser.apiRunner)(`replaceHydrateFunction`, undefined, _reactDom.default.hydrate)[0];
134 | (0, _domready.default)(() => {
135 | renderer( /*#__PURE__*/_react.default.createElement(NewRoot, null), typeof window !== `undefined` ? document.getElementById(`___gatsby`) : void 0, () => {
136 | (0, _apiRunnerBrowser.apiRunner)(`onInitialClientRender`);
137 | });
138 | });
139 | });
140 | });
--------------------------------------------------------------------------------
/.cache/commonjs/public-page-renderer-dev.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _react = _interopRequireDefault(require("react"));
9 |
10 | var _propTypes = _interopRequireDefault(require("prop-types"));
11 |
12 | var _loader = _interopRequireDefault(require("./loader"));
13 |
14 | var _queryResultStore = require("./query-result-store");
15 |
16 | const DevPageRenderer = ({
17 | location
18 | }) => {
19 | const pageResources = _loader.default.loadPageSync(location.pathname);
20 |
21 | return _react.default.createElement(_queryResultStore.PageQueryStore, {
22 | location,
23 | pageResources
24 | });
25 | };
26 |
27 | DevPageRenderer.propTypes = {
28 | location: _propTypes.default.shape({
29 | pathname: _propTypes.default.string.isRequired
30 | }).isRequired
31 | };
32 | var _default = DevPageRenderer;
33 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/public-page-renderer-prod.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _react = _interopRequireDefault(require("react"));
9 |
10 | var _propTypes = _interopRequireDefault(require("prop-types"));
11 |
12 | var _pageRenderer = _interopRequireDefault(require("./page-renderer"));
13 |
14 | const ProdPageRenderer = ({
15 | location,
16 | pageResources
17 | }) => {
18 | if (!pageResources) {
19 | return null;
20 | }
21 |
22 | return _react.default.createElement(_pageRenderer.default, {
23 | location,
24 | pageResources,
25 | ...pageResources.json
26 | });
27 | };
28 |
29 | ProdPageRenderer.propTypes = {
30 | location: _propTypes.default.shape({
31 | pathname: _propTypes.default.string.isRequired
32 | }).isRequired
33 | };
34 | var _default = ProdPageRenderer;
35 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/public-page-renderer.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | const preferDefault = m => m && m.default || m;
4 |
5 | if (process.env.BUILD_STAGE === `develop`) {
6 | module.exports = preferDefault(require(`./public-page-renderer-dev`));
7 | } else if (process.env.BUILD_STAGE === `build-javascript`) {
8 | module.exports = preferDefault(require(`./public-page-renderer-prod`));
9 | } else {
10 | module.exports = () => null;
11 | }
--------------------------------------------------------------------------------
/.cache/commonjs/query-result-store.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.StaticQueryStore = exports.PageQueryStore = void 0;
7 |
8 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9 |
10 | var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11 |
12 | var _react = _interopRequireDefault(require("react"));
13 |
14 | var _gatsby = require("gatsby");
15 |
16 | var _socketIo = require("./socketIo");
17 |
18 | var _pageRenderer = _interopRequireDefault(require("./page-renderer"));
19 |
20 | var _normalizePagePath = _interopRequireDefault(require("./normalize-page-path"));
21 |
22 | if (process.env.NODE_ENV === `production`) {
23 | throw new Error(`It appears like Gatsby is misconfigured. JSONStore is Gatsby internal ` + `development-only component and should never be used in production.\n\n` + `Unless your site has a complex or custom webpack/Gatsby ` + `configuration this is likely a bug in Gatsby. ` + `Please report this at https://github.com/gatsbyjs/gatsby/issues ` + `with steps to reproduce this error.`);
24 | }
25 |
26 | const getPathFromProps = props => props.pageResources && props.pageResources.page ? (0, _normalizePagePath.default)(props.pageResources.page.path) : undefined;
27 |
28 | class PageQueryStore extends _react.default.Component {
29 | constructor(props) {
30 | super(props);
31 | (0, _defineProperty2.default)(this, "handleMittEvent", () => {
32 | this.setState({
33 | pageQueryData: (0, _socketIo.getPageQueryData)()
34 | });
35 | });
36 | this.state = {
37 | pageQueryData: (0, _socketIo.getPageQueryData)(),
38 | path: null
39 | };
40 | }
41 |
42 | componentDidMount() {
43 | (0, _socketIo.registerPath)(getPathFromProps(this.props));
44 |
45 | ___emitter.on(`*`, this.handleMittEvent);
46 | }
47 |
48 | componentWillUnmount() {
49 | (0, _socketIo.unregisterPath)(this.state.path);
50 |
51 | ___emitter.off(`*`, this.handleMittEvent);
52 | }
53 |
54 | static getDerivedStateFromProps(props, state) {
55 | const newPath = getPathFromProps(props);
56 |
57 | if (newPath !== state.path) {
58 | (0, _socketIo.unregisterPath)(state.path);
59 | (0, _socketIo.registerPath)(newPath);
60 | return {
61 | path: newPath
62 | };
63 | }
64 |
65 | return null;
66 | }
67 |
68 | shouldComponentUpdate(nextProps, nextState) {
69 | // We want to update this component when:
70 | // - location changed
71 | // - page data for path changed
72 | return this.props.location !== nextProps.location || this.state.path !== nextState.path || this.state.pageQueryData[(0, _normalizePagePath.default)(nextState.path)] !== nextState.pageQueryData[(0, _normalizePagePath.default)(nextState.path)];
73 | }
74 |
75 | render() {
76 | const data = this.state.pageQueryData[getPathFromProps(this.props)]; // eslint-disable-next-line
77 |
78 | if (!data) {
79 | return (/*#__PURE__*/_react.default.createElement("div", null)
80 | );
81 | }
82 |
83 | return (/*#__PURE__*/_react.default.createElement(_pageRenderer.default, (0, _extends2.default)({}, this.props, data))
84 | );
85 | }
86 |
87 | }
88 |
89 | exports.PageQueryStore = PageQueryStore;
90 |
91 | class StaticQueryStore extends _react.default.Component {
92 | constructor(props) {
93 | super(props);
94 | (0, _defineProperty2.default)(this, "handleMittEvent", () => {
95 | this.setState({
96 | staticQueryData: (0, _socketIo.getStaticQueryData)()
97 | });
98 | });
99 | this.state = {
100 | staticQueryData: (0, _socketIo.getStaticQueryData)()
101 | };
102 | }
103 |
104 | componentDidMount() {
105 | ___emitter.on(`*`, this.handleMittEvent);
106 | }
107 |
108 | componentWillUnmount() {
109 | ___emitter.off(`*`, this.handleMittEvent);
110 | }
111 |
112 | shouldComponentUpdate(nextProps, nextState) {
113 | // We want to update this component when:
114 | // - static query results changed
115 | return this.state.staticQueryData !== nextState.staticQueryData;
116 | }
117 |
118 | render() {
119 | return (/*#__PURE__*/_react.default.createElement(_gatsby.StaticQueryContext.Provider, {
120 | value: this.state.staticQueryData
121 | }, this.props.children)
122 | );
123 | }
124 |
125 | }
126 |
127 | exports.StaticQueryStore = StaticQueryStore;
--------------------------------------------------------------------------------
/.cache/commonjs/react-lifecycles-compat.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.polyfill = Component => Component;
--------------------------------------------------------------------------------
/.cache/commonjs/register-service-worker.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _apiRunnerBrowser = require("./api-runner-browser");
4 |
5 | if (window.location.protocol !== `https:` && window.location.hostname !== `localhost`) {
6 | console.error(`Service workers can only be used over HTTPS, or on localhost for development`);
7 | } else if (`serviceWorker` in navigator) {
8 | navigator.serviceWorker.register(`${__BASE_PATH__}/sw.js`).then(function (reg) {
9 | reg.addEventListener(`updatefound`, () => {
10 | (0, _apiRunnerBrowser.apiRunner)(`onServiceWorkerUpdateFound`, {
11 | serviceWorker: reg
12 | }); // The updatefound event implies that reg.installing is set; see
13 | // https://w3c.github.io/ServiceWorker/#service-worker-registration-updatefound-event
14 |
15 | const installingWorker = reg.installing;
16 | console.log(`installingWorker`, installingWorker);
17 | installingWorker.addEventListener(`statechange`, () => {
18 | switch (installingWorker.state) {
19 | case `installed`:
20 | if (navigator.serviceWorker.controller) {
21 | // At this point, the old content will have been purged and the fresh content will
22 | // have been added to the cache.
23 | // We set a flag so Gatsby Link knows to refresh the page on next navigation attempt
24 | window.___swUpdated = true; // We call the onServiceWorkerUpdateReady API so users can show update prompts.
25 |
26 | (0, _apiRunnerBrowser.apiRunner)(`onServiceWorkerUpdateReady`, {
27 | serviceWorker: reg
28 | }); // If resources failed for the current page, reload.
29 |
30 | if (window.___failedResources) {
31 | console.log(`resources failed, SW updated - reloading`);
32 | window.location.reload();
33 | }
34 | } else {
35 | // At this point, everything has been precached.
36 | // It's the perfect time to display a "Content is cached for offline use." message.
37 | console.log(`Content is now available offline!`); // Post to service worker that install is complete.
38 | // Delay to allow time for the event listener to be added --
39 | // otherwise fetch is called too soon and resources aren't cached.
40 |
41 | (0, _apiRunnerBrowser.apiRunner)(`onServiceWorkerInstalled`, {
42 | serviceWorker: reg
43 | });
44 | }
45 |
46 | break;
47 |
48 | case `redundant`:
49 | console.error(`The installing service worker became redundant.`);
50 | (0, _apiRunnerBrowser.apiRunner)(`onServiceWorkerRedundant`, {
51 | serviceWorker: reg
52 | });
53 | break;
54 |
55 | case `activated`:
56 | (0, _apiRunnerBrowser.apiRunner)(`onServiceWorkerActive`, {
57 | serviceWorker: reg
58 | });
59 | break;
60 | }
61 | });
62 | });
63 | }).catch(function (e) {
64 | console.error(`Error during service worker registration:`, e);
65 | });
66 | }
--------------------------------------------------------------------------------
/.cache/commonjs/root.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = void 0;
7 |
8 | var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9 |
10 | var _react = _interopRequireDefault(require("react"));
11 |
12 | var _router = require("@reach/router");
13 |
14 | var _gatsbyReactRouterScroll = require("gatsby-react-router-scroll");
15 |
16 | var _navigation = require("./navigation");
17 |
18 | var _apiRunnerBrowser = require("./api-runner-browser");
19 |
20 | var _loader = _interopRequireDefault(require("./loader"));
21 |
22 | var _queryResultStore = require("./query-result-store");
23 |
24 | var _ensureResources = _interopRequireDefault(require("./ensure-resources"));
25 |
26 | var _errorOverlayHandler = require("./error-overlay-handler");
27 |
28 | // TODO: Remove entire block when we make fast-refresh the default
29 | // In fast-refresh, this logic is all moved into the `error-overlay-handler`
30 | if (window.__webpack_hot_middleware_reporter__ !== undefined && process.env.GATSBY_HOT_LOADER !== `fast-refresh`) {
31 | const overlayErrorID = `webpack`; // Report build errors
32 |
33 | window.__webpack_hot_middleware_reporter__.useCustomOverlay({
34 | showProblems(type, obj) {
35 | if (type !== `errors`) {
36 | (0, _errorOverlayHandler.clearError)(overlayErrorID);
37 | return;
38 | }
39 |
40 | (0, _errorOverlayHandler.reportError)(overlayErrorID, obj[0]);
41 | },
42 |
43 | clear() {
44 | (0, _errorOverlayHandler.clearError)(overlayErrorID);
45 | }
46 |
47 | });
48 | }
49 |
50 | (0, _navigation.init)(); // In gatsby v2 if Router is used in page using matchPaths
51 | // paths need to contain full path.
52 | // For example:
53 | // - page have `/app/*` matchPath
54 | // - inside template user needs to use `/app/xyz` as path
55 | // Resetting `basepath`/`baseuri` keeps current behaviour
56 | // to not introduce breaking change.
57 | // Remove this in v3
58 |
59 | const RouteHandler = props => /*#__PURE__*/_react.default.createElement(_router.BaseContext.Provider, {
60 | value: {
61 | baseuri: `/`,
62 | basepath: `/`
63 | }
64 | }, /*#__PURE__*/_react.default.createElement(_queryResultStore.PageQueryStore, props));
65 |
66 | class LocationHandler extends _react.default.Component {
67 | render() {
68 | const {
69 | location
70 | } = this.props;
71 |
72 | if (!_loader.default.isPageNotFound(location.pathname)) {
73 | return (/*#__PURE__*/_react.default.createElement(_ensureResources.default, {
74 | location: location
75 | }, locationAndPageResources => /*#__PURE__*/_react.default.createElement(_navigation.RouteUpdates, {
76 | location: location
77 | }, /*#__PURE__*/_react.default.createElement(_gatsbyReactRouterScroll.ScrollContext, {
78 | location: location,
79 | shouldUpdateScroll: _navigation.shouldUpdateScroll
80 | }, /*#__PURE__*/_react.default.createElement(_router.Router, {
81 | basepath: __BASE_PATH__,
82 | location: location,
83 | id: "gatsby-focus-wrapper"
84 | }, /*#__PURE__*/_react.default.createElement(RouteHandler, (0, _extends2.default)({
85 | path: encodeURI(locationAndPageResources.pageResources.page.matchPath || locationAndPageResources.pageResources.page.path)
86 | }, this.props, locationAndPageResources))))))
87 | );
88 | }
89 |
90 | const dev404PageResources = _loader.default.loadPageSync(`/dev-404-page`);
91 |
92 | const real404PageResources = _loader.default.loadPageSync(`/404.html`);
93 |
94 | let custom404;
95 |
96 | if (real404PageResources) {
97 | custom404 = /*#__PURE__*/_react.default.createElement(_queryResultStore.PageQueryStore, (0, _extends2.default)({}, this.props, {
98 | pageResources: real404PageResources
99 | }));
100 | }
101 |
102 | return (/*#__PURE__*/_react.default.createElement(_navigation.RouteUpdates, {
103 | location: location
104 | }, /*#__PURE__*/_react.default.createElement(_router.Router, {
105 | basepath: __BASE_PATH__,
106 | location: location,
107 | id: "gatsby-focus-wrapper"
108 | }, /*#__PURE__*/_react.default.createElement(RouteHandler, {
109 | path: location.pathname,
110 | location: location,
111 | pageResources: dev404PageResources,
112 | custom404: custom404
113 | })))
114 | );
115 | }
116 |
117 | }
118 |
119 | const Root = () => /*#__PURE__*/_react.default.createElement(_router.Location, null, locationContext => /*#__PURE__*/_react.default.createElement(LocationHandler, locationContext)); // Let site, plugins wrap the site e.g. for Redux.
120 |
121 |
122 | const WrappedRoot = (0, _apiRunnerBrowser.apiRunner)(`wrapRootElement`, {
123 | element: /*#__PURE__*/_react.default.createElement(Root, null)
124 | }, /*#__PURE__*/_react.default.createElement(Root, null), ({
125 | result,
126 | plugin
127 | }) => {
128 | return {
129 | element: result
130 | };
131 | }).pop();
132 |
133 | var _default = () => /*#__PURE__*/_react.default.createElement(_queryResultStore.StaticQueryStore, null, WrappedRoot);
134 |
135 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/commonjs/route-announcer-props.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.__esModule = true;
4 | exports.RouteAnnouncerProps = void 0;
5 | // This is extracted to separate module because it's shared
6 | // between browser and SSR code
7 | const RouteAnnouncerProps = {
8 | id: `gatsby-announcer`,
9 | style: {
10 | position: `absolute`,
11 | top: 0,
12 | width: 1,
13 | height: 1,
14 | padding: 0,
15 | overflow: `hidden`,
16 | clip: `rect(0, 0, 0, 0)`,
17 | whiteSpace: `nowrap`,
18 | border: 0
19 | },
20 | "aria-live": `assertive`,
21 | "aria-atomic": `true`
22 | };
23 | exports.RouteAnnouncerProps = RouteAnnouncerProps;
--------------------------------------------------------------------------------
/.cache/commonjs/socketIo.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4 |
5 | exports.__esModule = true;
6 | exports.default = socketIo;
7 | exports.getPageData = getPageData;
8 | exports.registerPath = registerPath;
9 | exports.unregisterPath = unregisterPath;
10 | exports.getIsInitialized = exports.getPageQueryData = exports.getStaticQueryData = void 0;
11 |
12 | var _errorOverlayHandler = require("./error-overlay-handler");
13 |
14 | var _normalizePagePath = _interopRequireDefault(require("./normalize-page-path"));
15 |
16 | let socket = null;
17 | let staticQueryData = {};
18 | let pageQueryData = {};
19 | let isInitialized = false;
20 |
21 | const getStaticQueryData = () => staticQueryData;
22 |
23 | exports.getStaticQueryData = getStaticQueryData;
24 |
25 | const getPageQueryData = () => pageQueryData;
26 |
27 | exports.getPageQueryData = getPageQueryData;
28 |
29 | const getIsInitialized = () => isInitialized;
30 |
31 | exports.getIsInitialized = getIsInitialized;
32 |
33 | function socketIo() {
34 | if (process.env.NODE_ENV !== `production`) {
35 | if (!socket) {
36 | // Try to initialize web socket if we didn't do it already
37 | try {
38 | // eslint-disable-next-line no-undef
39 | socket = io();
40 |
41 | const didDataChange = (msg, queryData) => {
42 | const id = msg.type === `staticQueryResult` ? msg.payload.id : (0, _normalizePagePath.default)(msg.payload.id);
43 | return !(id in queryData) || JSON.stringify(msg.payload.result) !== JSON.stringify(queryData[id]);
44 | };
45 |
46 | socket.on(`message`, msg => {
47 | if (msg.type === `staticQueryResult`) {
48 | if (didDataChange(msg, staticQueryData)) {
49 | staticQueryData = { ...staticQueryData,
50 | [msg.payload.id]: msg.payload.result
51 | };
52 | }
53 | } else if (msg.type === `pageQueryResult`) {
54 | if (didDataChange(msg, pageQueryData)) {
55 | pageQueryData = { ...pageQueryData,
56 | [(0, _normalizePagePath.default)(msg.payload.id)]: msg.payload.result
57 | };
58 | }
59 | } else if (msg.type === `overlayError`) {
60 | if (msg.payload.message) {
61 | (0, _errorOverlayHandler.reportError)(msg.payload.id, msg.payload.message);
62 | } else {
63 | (0, _errorOverlayHandler.clearError)(msg.payload.id);
64 | }
65 | }
66 |
67 | if (msg.type && msg.payload) {
68 | ___emitter.emit(msg.type, msg.payload);
69 | }
70 | });
71 | } catch (err) {
72 | console.error(`Could not connect to socket.io on dev server.`);
73 | }
74 | }
75 |
76 | return socket;
77 | } else {
78 | return null;
79 | }
80 | }
81 |
82 | const inFlightGetPageDataPromiseCache = {};
83 |
84 | function getPageData(pathname) {
85 | pathname = (0, _normalizePagePath.default)(pathname);
86 |
87 | if (inFlightGetPageDataPromiseCache[pathname]) {
88 | return inFlightGetPageDataPromiseCache[pathname];
89 | } else {
90 | inFlightGetPageDataPromiseCache[pathname] = new Promise(resolve => {
91 | if (pageQueryData[pathname]) {
92 | delete inFlightGetPageDataPromiseCache[pathname];
93 | resolve(pageQueryData[pathname]);
94 | } else {
95 | const onPageDataCallback = msg => {
96 | if (msg.type === `pageQueryResult` && (0, _normalizePagePath.default)(msg.payload.id) === pathname) {
97 | socket.off(`message`, onPageDataCallback);
98 | delete inFlightGetPageDataPromiseCache[pathname];
99 | resolve(pageQueryData[pathname]);
100 | }
101 | };
102 |
103 | socket.on(`message`, onPageDataCallback);
104 | socket.emit(`getDataForPath`, pathname);
105 | }
106 | });
107 | }
108 |
109 | return inFlightGetPageDataPromiseCache[pathname];
110 | } // Tell websocket-manager.js the new path we're on.
111 | // This will help the backend prioritize queries for this
112 | // path.
113 |
114 |
115 | function registerPath(path) {
116 | socket.emit(`registerPath`, path);
117 | } // Unregister the former path
118 |
119 |
120 | function unregisterPath(path) {
121 | socket.emit(`unregisterPath`, path);
122 | }
--------------------------------------------------------------------------------
/.cache/commonjs/strip-prefix.js:
--------------------------------------------------------------------------------
1 | "use strict";
2 |
3 | exports.__esModule = true;
4 | exports.default = void 0;
5 |
6 | /**
7 | * Remove a prefix from a string. Return the input string if the given prefix
8 | * isn't found.
9 | */
10 | var _default = (str, prefix = ``) => {
11 | if (!prefix) {
12 | return str;
13 | }
14 |
15 | prefix += `/`;
16 |
17 | if (str.substr(0, prefix.length) === prefix) {
18 | return str.slice(prefix.length - 1);
19 | }
20 |
21 | return str;
22 | };
23 |
24 | exports.default = _default;
--------------------------------------------------------------------------------
/.cache/create-react-context.js:
--------------------------------------------------------------------------------
1 | import React from "react"
2 |
3 | export default React.createContext
4 |
--------------------------------------------------------------------------------
/.cache/default-html.js:
--------------------------------------------------------------------------------
1 | import React from "react"
2 | import PropTypes from "prop-types"
3 |
4 | export default function HTML(props) {
5 | return (
6 |
7 |
8 |
9 |
10 |
14 | {props.headComponents}
15 |
16 |
17 | {props.preBodyComponents}
18 |
23 | {props.postBodyComponents}
24 |
25 |
26 | )
27 | }
28 |
29 | HTML.propTypes = {
30 | htmlAttributes: PropTypes.object,
31 | headComponents: PropTypes.array,
32 | bodyAttributes: PropTypes.object,
33 | preBodyComponents: PropTypes.array,
34 | body: PropTypes.string,
35 | postBodyComponents: PropTypes.array,
36 | }
37 |
--------------------------------------------------------------------------------
/.cache/dev-404-page.js:
--------------------------------------------------------------------------------
1 | import React from "react"
2 | import PropTypes from "prop-types"
3 | import { graphql, Link, navigate } from "gatsby"
4 | import queryString from "query-string"
5 |
6 | class Dev404Page extends React.Component {
7 | static propTypes = {
8 | data: PropTypes.object,
9 | custom404: PropTypes.element,
10 | location: PropTypes.object,
11 | }
12 |
13 | constructor(props) {
14 | super(props)
15 | const { data, location } = this.props
16 | const pagePaths = data.allSitePage.nodes.map(node => node.path)
17 | const urlState = queryString.parse(location.search)
18 |
19 | const initialPagePathSearchTerms = urlState.filter ? urlState.filter : ``
20 |
21 | this.state = {
22 | showCustom404: false,
23 | initPagePaths: pagePaths,
24 | pagePathSearchTerms: initialPagePathSearchTerms,
25 | pagePaths: this.getFilteredPagePaths(
26 | pagePaths,
27 | initialPagePathSearchTerms
28 | ),
29 | }
30 | this.showCustom404 = this.showCustom404.bind(this)
31 | this.handlePagePathSearch = this.handlePagePathSearch.bind(this)
32 | this.handleSearchTermChange = this.handleSearchTermChange.bind(this)
33 | }
34 |
35 | showCustom404() {
36 | this.setState({ showCustom404: true })
37 | }
38 |
39 | handleSearchTermChange(event) {
40 | const searchValue = event.target.value
41 |
42 | this.setSearchUrl(searchValue)
43 |
44 | this.setState({
45 | pagePathSearchTerms: searchValue,
46 | })
47 | }
48 |
49 | handlePagePathSearch(event) {
50 | event.preventDefault()
51 | const allPagePaths = [...this.state.initPagePaths]
52 | this.setState({
53 | pagePaths: this.getFilteredPagePaths(
54 | allPagePaths,
55 | this.state.pagePathSearchTerms
56 | ),
57 | })
58 | }
59 |
60 | getFilteredPagePaths(allPagePaths, pagePathSearchTerms) {
61 | const searchTerm = new RegExp(`${pagePathSearchTerms}`)
62 | return allPagePaths.filter(pagePath => searchTerm.test(pagePath))
63 | }
64 |
65 | setSearchUrl(searchValue) {
66 | const {
67 | location: { pathname, search },
68 | } = this.props
69 |
70 | const searchMap = queryString.parse(search)
71 | searchMap.filter = searchValue
72 |
73 | const newSearch = queryString.stringify(searchMap)
74 |
75 | if (search !== `?${newSearch}`) {
76 | navigate(`${pathname}?${newSearch}`, { replace: true })
77 | }
78 | }
79 |
80 | render() {
81 | const { pathname } = this.props.location
82 | let newFilePath
83 | if (pathname === `/`) {
84 | newFilePath = `src/pages/index.js`
85 | } else if (pathname.slice(-1) === `/`) {
86 | newFilePath = `src/pages${pathname.slice(0, -1)}.js`
87 | } else {
88 | newFilePath = `src/pages${pathname}.js`
89 | }
90 |
91 | return this.state.showCustom404 ? (
92 | this.props.custom404
93 | ) : (
94 |
95 |
Gatsby.js development 404 page
96 |
97 | {`There's not a page yet at `}
98 | {pathname}
99 |
100 | {this.props.custom404 ? (
101 |
102 |
105 |
106 | ) : (
107 |
108 | {`A custom 404 page wasn't detected - if you would like to add one, create a component in your site directory at `}
109 | src/pages/404.js.
110 |
111 | )}
112 |
113 | Create a React.js component in your site directory at
114 | {` `}
115 | {newFilePath}
116 | {` `}
117 | and this page will automatically refresh to show the new page
118 | component you created.
119 |