mirror of
https://github.com/revoltchat/revite.git
synced 2024-11-12 18:29:57 -05:00
33 lines
727 B
TypeScript
33 lines
727 B
TypeScript
|
import { store } from ".";
|
||
|
import localForage from "localforage";
|
||
|
import { Provider } from 'react-redux';
|
||
|
import { Children } from "../types/Preact";
|
||
|
import { useEffect, useState } from "preact/hooks";
|
||
|
|
||
|
async function loadState() {
|
||
|
const state = await localForage.getItem("state");
|
||
|
if (state) {
|
||
|
store.dispatch({ type: "__INIT", state });
|
||
|
}
|
||
|
}
|
||
|
|
||
|
interface Props {
|
||
|
children: Children
|
||
|
}
|
||
|
|
||
|
export default function State(props: Props) {
|
||
|
const [loaded, setLoaded] = useState(false);
|
||
|
|
||
|
useEffect(() => {
|
||
|
loadState().then(() => setLoaded(true));
|
||
|
}, []);
|
||
|
|
||
|
if (!loaded) return null;
|
||
|
|
||
|
return (
|
||
|
<Provider store={store}>
|
||
|
{ props.children }
|
||
|
</Provider>
|
||
|
)
|
||
|
}
|