TypeError: render - это не функция, реагирующая на хуки
Я использовал Redux, но впервые работал с концепцией контекста поставщика и потребителя, работая над ней последние 2 дня.
Ниже приведен код. Я хочу добавить поставщика и потребителя в один файл. Это возможно? Если да, то мой подход правильный? Если не где я ошибаюсь? Я хочу использовать значения в макете и его дочернем компоненте. Правильно ли мой подход?
index.js
ReactDOM.render(
<Router>
<ClientContext.Provider value={client}>// graphQL Provider
<CommonProvider>
<Switch>
<MyProvider.Consumer>{
(value) =>{
<Layout {...value} >
<Switch>
<Route exact path="/" render={props => (
<Installation {...props} />
)} />
<Route path="/xyz" component={xyz} />
</Switch>
</Layout>
}}
</MyProvider.Consumer>
</Switch>
</CommonProvider>
</ClientContext.Provider>
</Router>,
document.getElementById('root')
);
Provider.js
import React ,{ createContext,useState,useContext,useEffect } from "react";
import Sign from '/loginpage';
const MyProvider=createContext({});
export default MyProvider;
export const CommonProvider =props=>{
const [value,setValue]=useState("");
const DataContext={value,setValue};
useEffect(()=>{console.log("Data Provider",value,"props",props,"DataContext",DataContext)})
return(
<MyProvider.Provider value={DataContext}>
{props.children}
</MyProvider.Provider>
);
};
const UseHOC=WrapperComponent=>function Comp(props){
const dataCtx=useContext(MyProvider);
useEffect(()=>{console.log("propsHOC",props,"MyProvider",MyProvider,"dataCtx",dataCtx)})
if(value.isUser)
return(
<WrapperComponent
{...props}
value={dataCtx.value}
setValue={dataCtx.setValue}
/>
);
else
return <Sign/>
};
export { UseHOC };
Правильно ли я написал поставщика и HOC? Должен ли я поместить его в другой файл? Мне вообще нужен HOC?
Любая помощь приветствуется. Есть ли другой способ?