Novice learning react-redux problem

redux rookie, want to write a demo, with react-redux click login to transfer data

index.js:

const store = createStore(reducer)
ReactDOM.render(
    (
        <Provider store = {store}>
            <Router>
                <div>
                    <Route exact path="/" component={App}/>
                    <Route path="/main" component={main}/>
                </div>
            </Router>
        </Provider>
    ),
    document.getElementById("root")
)
APP.js:

import React, {Component} from "react";
import "./App.css";
import {bindActionCreators} from "redux"
import {connect} from "react-redux"
import {login} from "./action/action"

class App extends Component {
    clickLogin(event) {
        this.props.login;
        this.props.history.push("/main/router");
    }
    render() {
        return (
            <div className="App">
                <button onClick={this.clickLogin.bind(this)}></button>
            </div>
        );
    }
}


const mapStateToProps = (state, ownProps) => {
    return {
        msg: state.msg ? state.msg : ownProps.msg
    }
}
const mapDispatchToProps = (dispatch, ownProps) => {
    return {
        login:bindActionCreators(login,dispatch)
    }
}
export default connect(
    mapStateToProps,
    mapDispatchToProps
)(App)
action.js:

const actions = {
    sendShowChineseMsg: () => ({ type: "chinese" }),
    sendShowEnglishMsg: () => ({ type: "english" })
}

export function login() {
    return dispatch=>{
        dispatch(actions.sendShowChineseMsg())
    }
}
reducer:

const reducer = (state = {}, action) => {
    switch (action.type) {
        case "chinese":
            return {
                state,
                msg: "Redux"
            }
        case "english":
            return {
                state,
                msg: "This is Redux"
            }
        default:
            return state
    }
}

export default reducer;
router:

import React, { Component } from "react";

class router extends Component {
    render() {
        return (
            <div className="App">
                <h1>{this.props.msg}</h1>
            </div>
        );
    }
}

export default router;

tell me where there is a problem. The information of msg cannot be displayed in router

.

const reducer = (state = {}, action) => {
    switch (action.type) {
        case 'chinese':
            return {
                ...state,
                ...{msg: 'Redux'}
            }
        case 'english':
            return {
                ...state,
                ...{msg: "This is Redux"}
            }
        default:
            return state
    }
}

change it to this

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1bf2aca-31dfd.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1bf2aca-31dfd.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?