Машинопись HOC с React.createContext

У меня есть этот.js фрагмент, который мне нужно перевести на Typescript.

import React from 'react';

const FirebaseContext = React.createContext(null)

export const withFirebase = Component => props => (
    <FirebaseContext.Consumer>
        {firebase => <Component {...props} firebase={firebase} />}
    </FirebaseContext.Consumer>
)

export default FirebaseContext

мое лучшее предположение

const FirebaseContext = React.createContext(null)

export const withFirebase = (Component: React.ComponentClass) => (props: any) => (
    <FirebaseContext.Consumer>
        {firebase => <Component {...props} firebase={firebase} />}
    </FirebaseContext.Consumer>
)

но когда я пытаюсь использовать контекст - передавая new Firebase():

import React from 'react';
import ReactDOM from 'react-dom';

import './index.css';
import * as serviceWorker from './serviceWorker';

import App from './components/App';
import Firebase, { FirebaseContext } from './components/Firebase';

ReactDOM.render(
    <FirebaseContext.Provider value={new Firebase()}>
        <App />
    </FirebaseContext.Provider>,
    document.getElementById('root'),
);

serviceWorker.unregister()

в этом случае - я получаю Type 'Firebase' is not assignable to type 'null'.

1 ответ

Решение

Вы, кажется, не указали ни одного типа createContext, Добавление типа Firebase к нему должно работать

const FirebaseContext = React.createContext<Firebase | null>(null);

Еще лучше создать тип и использовать Partial для значений по умолчанию:

type FirebaseContextProps = {
  firebase: Firebase
  isOk: boolean
  data: string
}

const FirebaseContext= React.createContext<Partial<FirebaseContextProps>>({})

<FirebaseContext.Provider value={{ firebase, isOk, data }}>
Другие вопросы по тегам