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?

Любая помощь приветствуется. Есть ли другой способ?

0 ответов

Другие вопросы по тегам