import React from 'react'; import { connect } from 'react-redux'; import { Theme } from 'config'; import { configMetaActions, configMetaSelectors } from 'features/config'; import { AppState } from 'features/reducers'; import './ThemeToggle.scss'; interface ActionProps { changeTheme: typeof configMetaActions.changeTheme; } interface StateProps { theme: ReturnType; } type Props = ActionProps & StateProps; class ThemeToggle extends React.Component { public render() { return ( ); } private toggleTheme = () => { const theme = this.props.theme === Theme.LIGHT ? Theme.DARK : Theme.LIGHT; this.props.changeTheme(theme); }; } export default connect( (state: AppState) => ({ theme: configMetaSelectors.getTheme(state) }), { changeTheme: configMetaActions.changeTheme } )(ThemeToggle);