-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathmain-heading-context.js
37 lines (27 loc) · 1.13 KB
/
main-heading-context.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
import React, { createContext, useContext, useEffect, useMemo, useState } from "react";
const DEFAULT_MAIN_HEADING = 'CampSpots'
// create context
const MainHeadingContext = createContext({ mainHeading: DEFAULT_MAIN_HEADING, setMainHeading: () => {} });
const MainHeadingContextProvider = ({ children }) => {
// the value that will be given to the context
const [mainHeading, setMainHeading] = useState(DEFAULT_MAIN_HEADING);
const context = useMemo(() => ({
mainHeading,
setMainHeading
}), [mainHeading, setMainHeading])
return (
// the Provider gives access to the context to its children
<MainHeadingContext.Provider value={context}>
{children}
</MainHeadingContext.Provider>
);
};
const useMainHeading = (mainHeading = '') => {
const {setMainHeading} = useContext(MainHeadingContext);
useEffect(() => {
const newMainHeading = `${DEFAULT_MAIN_HEADING}${mainHeading ? ' - ': ''}${mainHeading}`
setMainHeading(newMainHeading)
return () => setMainHeading(DEFAULT_MAIN_HEADING)
}, [mainHeading])
}
export {MainHeadingContext, MainHeadingContextProvider, useMainHeading}