-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAnimationContext.jsx
More file actions
32 lines (27 loc) · 780 Bytes
/
Copy pathAnimationContext.jsx
File metadata and controls
32 lines (27 loc) · 780 Bytes
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
import React, { createContext, useContext } from 'react';
import usePersistentState from '../hooks/usePersistentState';
const AnimationContext = createContext();
export const AnimationProvider = ({ children }) => {
// We use the existing key but invert the logic mentally or rename it.
// Let's use a new key for clarity: reduceMotion
const [reduceMotion, setReduceMotion] = usePersistentState(
'reduceMotion',
false,
);
const toggleReduceMotion = () => {
setReduceMotion((prev) => !prev);
};
return (
<AnimationContext.Provider
value={{
reduceMotion,
toggleReduceMotion,
}}
>
{children}
</AnimationContext.Provider>
);
};
export const useAnimation = () => {
return useContext(AnimationContext);
};