import React from "react";
import { Equal, Expect } from "../helpers/type-utils";
const createRequiredContext = <T extends any>() => {
const context = React.createContext<T | null>(null);
const useContext = <T extends any>() => {
const contextValue = React.useContext(context);
if (contextValue === null) {
throw new Error("Context value is null");
}
return contextValue;
};
return [useContext, context.Provider] as const;
};
const [useUser, UserProvider] = createRequiredContext<{
name: string;
}>();
const [useTheme, ThemeProvider] = createRequiredContext<{
primaryColor: string;
}>();
const Child = () => {
const user = useUser();
type test = Expect<
Equal<
typeof user,
{
name: string;
}
>
>;
const theme = useTheme();
type test2 = Expect<
Equal<
typeof theme,
{
primaryColor: string;
}
>
>;
return null;
};
const Parent = () => {
return (
<>
<UserProvider value={{ name: "Matt" }}>
<ThemeProvider
value={{
primaryColor: "blue",
}}
>
<Child />
</ThemeProvider>
</UserProvider>
</>
);
};
- React Typescript provider Context typedreact typescript provider context composable component context react typescript this type type typescript expression error performance typescript interface type typescript predicates type all react react-query context query element invalid react type type-coverage typescript源码coverage typescript interface type