summaryrefslogtreecommitdiff
path: root/front-end/src/app.jsx
blob: 60f0002b5fc3f1a629a6d1f55fd0629ba393f25b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import React from 'react';
import ReactDom from 'react-dom';
import {HashRouter as Router, Route, Link, Redirect, Switch} from 'react-router-dom';
import createHistory from 'history/createHashHistory'
const history = createHistory()
import {spring, AnimatedRoute, AnimatedSwitch} from 'react-router-transition';
// layout
import Layout from 'component/layout/index.jsx'
// page
import Login from './page/login/index.jsx'
import Home from './page/home/index.jsx'
import Status from './page/status/index.jsx'
import Machine from './page/machine/index.jsx'
import PPolicy from './page/ppolicy/index.jsx'

import DetailInfo from './page/detailInfo/index.jsx'
import MachinelInfo from './page/machineInfo/index.jsx'

import Portal from './page/portal/index.jsx'
import FarmerApply from './page/farmerApply/index.jsx'

// we need to map the `scale` prop we define below
// to the transform style property
function mapStyles(styles) {
    return {
        opacity: styles.opacity,
        transform: `scale(${styles.scale})`,
    };
}

// wrap the `spring` helper to use a bouncy config
function bounce(val) {
    return spring(val, {
        stiffness: 330,
        damping: 22,
    });
}

// child matches will...
const bounceTransition = {
    // start in a transparent, upscaled state
    atEnter: {
        opacity: 0,
        scale: 1.2,
    },
    // leave in a transparent, downscaled state
    atLeave: {
        opacity: bounce(0),
        scale: bounce(0.8),
    },
    // and rest at an opaque, normally-scaled state
    atActive: {
        opacity: bounce(1),
        scale: bounce(1),
    },
};

class App extends React.Component {
    constructor(props) {
        super(props);
    }


    render() {
        let LayoutRouter = (
            <Layout>
                    <Route exact path="/login/" component={Login}/>
                    <Route exact path="/" component={Home}/>

                    <Route exact path="/home/" component={Home}/>
                    <Route exact path="/status/" component={Status}/>
                    <Route exact path="/machine/" component={Machine}/>
                    <Route exact path="/ppolicy/" component={PPolicy}/>

                    <Route exact path="/portal/" component={Portal}/>
                    <Route exact path="/farmerApply/" component={FarmerApply}/>
                    <Route path="/detailInfo/:uuid" component={DetailInfo}/>
                    <Route path="/machineInfo/:machine_sn" component={MachinelInfo}/>
                    {/*<Redirect exact from="/order" to="/order/index"/>*/}
                    {/*<Redirect exact from="/user" to="/user/index"/>*/}
                    {/*<Route component={ErrorPage}/>*/}
            </Layout>
        );
        return (
            <Router>
                <AnimatedSwitch
                    atEnter={bounceTransition.atEnter}
                    atLeave={bounceTransition.atLeave}
                    atActive={bounceTransition.atActive}
                    mapStyles={mapStyles}
                    className="route-wrapper"
                >
                    {/*<Route path="/login" component={Login}/>*/}
                    <Route path="/" render={ props => LayoutRouter}/>
                </AnimatedSwitch>
            </Router>
        )
    }
}

ReactDom.render(
    <App />,
    document.getElementById("app")
);