Как использовать диспетчеризацию в компоненте класса или как изменить мой HOC - PullRequest
0 голосов
/ 09 ноября 2019

У меня есть следующий компонент HOC, который работает нормально, но он выдает ошибку при отправке. Я не могу использовать его внутри компонента класса, но как мне это исправить?

const withAuthentication = <Props extends object>(
  Component: React.ComponentType<Props>
) => {
  class WithAuthentication extends React.Component<Props & FirebaseInterface> {
    render(): React.ReactNode {
      const { firebase, ...props } = this.props
      const dispatch = useDispatch()
      const [authenticated, setAuthenticated] = useState(false)
      const { userId, loggedIn } = useSelector(
        (state: Record<string, ReduxProvider>) => state.user
      )

      useEffect(() => {
        const listener = firebase.auth.onAuthStateChanged(authUser => {
          if (authUser) {
            console.log(authUser)
            if (!loggedIn) {
              firebase.user(userId).once('value', snapshot => {
                dispatch(
              )
              })
            }

            setAuthenticated(true)
          } else {
            dispatch(
              addUser({

              })
            )

            setAuthenticated(false)
          }
        })

        return (): void => {
          listener()
        }
      }, [setAuthenticated, firebase, dispatch, loggedIn, userId])
    }
  }

  return withFirebase(WithAuthentication)
}

export default withAuthentication

Любая помощь будет оценена!

1 Ответ

0 голосов
/ 09 ноября 2019

Вы не можете использовать useDispatch в компоненте класса.

Вы должны использовать import.

import {connect} from 'react-redux'
import {compose} from 'redux'

...
const {dispatch} = this.props
...
return compose(withFirebase, connect(state => ({}), dispatch => ({dispatch})) )(WithAuthentication)
...

...
...