const withTheme = Component => ({ userPalette, ...props }) => (
<ThemeProvider theme={defaultMaterialTheme(userPalette)}>
<Component {...props} />
</ThemeProvider>
);
export default compose(
hot,
connect(mapStateToProps),
withTheme,
)(Routes);
const SignIn = ({ isAuth }) => {
useEffect(() => {
if (isAuth) {
history.push('/')
}
}, [isAuth])
}
<Route ... component={SignIn} />
=> props.historyconst ChildComponent = (props) => (
<div
className={`childComponent ${props.isActive ? 'active' : ''}`}
onClick={props.onClick}
data-id={props.id}
>
<h3>{props.text}</h3>
</div>
);
const ParentComponent = ({ items }) => {
const [ active, setActive ] = React.useState(null);
const onClick = e => setActive(+e.currentTarget.dataset.id);
// или
// const onClick = e => setActive(+e.target.closest('[data-id]').dataset.id);
return (
<div>
{items.map(n =>
<ChildComponent
key={n.id}
onClick={onClick}
isActive={n.id === active}
{...n}
/>
)}
</div>
)
};
ReactDOM.render(
<ParentComponent
items={[
{ id: 69, text: 'hello, world!!' },
{ id: 187, text: 'fuck the world' },
{ id: 666, text: 'fuck everything' },
]}
/>,
document.getElementById('root')
);