Я пытаюсь динамически установить контекст в родительском компоненте из дочернего компонента, используя этот пост в качестве руководства
Вот мой App.tsx:
export interface User {
username: string;
}
export interface iUserContext {
users: User[];
setUsers: React.Dispatch<React.SetStateAction<User[]>>;
}
function App() {
const [users, setUsers] = useState<User[]>([]);
const value = { users, setUsers };
// set defaults
const UsersContext = createContext<iUserContext>({
users: [],
setUsers: () => {},
});
return (
<div className="App">
<Router>
<UsersContext.Provider value={value}>
<Layout>
<Switch>
<Route path="/generated-links">
<GeneratedLinks />
</Route>
<Route path="/">
<GenerateLinks />
</Route>
</Switch>
</Layout>
</UsersContext.Provider>
</Router>
</div>
);
}
Затем в GenerateLinks.tsx:
const GenerateLinks = () => {
const history = useHistory();
const { users, setUsers } = useContext<iUserContext>(UsersContext);
Ошибка, которую я получаю, относится к аргументу UsersContext, только здесь ^:
Cannot find name 'UsersContext'. Did you mean 'useContext'?
Я раньше не использовал useContext и TS вместе, поэтому, возможно, я упускаю что-то очевидное, но похоже, что TS не обнаруживает, что я оборачиваю этот компонент поставщиком контекста пользователя и передаю его. Есть идеи?