-
Notifications
You must be signed in to change notification settings - Fork 0
/
gatsby-ssr.js
46 lines (41 loc) · 1.19 KB
/
gatsby-ssr.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/**
* Implement Gatsby's Browser APIs in this file.
*
* See: https://www.gatsbyjs.org/docs/browser-apis/
*/
import React from "react";
import { StateProvider } from "./src/context/StateContext";
import "./src/components/layout.css";
export const wrapRootElement = ({ element }) => {
const componentData = { name: "", questions: {} };
console.log("componentData", componentData.name);
const initialState = {
name: componentData ? componentData.name : "",
questions: componentData ? componentData.questions : {}
};
const reducer = (state, action) => {
switch (action.type) {
case "updateName":
const nameData = {
...state,
name: action.newData
};
localStorage.setItem("ComponentData", JSON.stringify(nameData));
return nameData;
case "updateQuestions":
const questionData = {
...state,
questions: action.newData
};
localStorage.setItem("ComponentData", JSON.stringify(questionData));
return questionData;
default:
return state;
}
};
return (
<StateProvider initialState={initialState} reducer={reducer}>
{element}
</StateProvider>
);
};