summaryrefslogtreecommitdiff
path: root/frontend/src/pages/Simulations.js
blob: ce2386fdc7fa7e310a30c0293d3a6c1de598d6b3 (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
import React from 'react'
import DocumentTitle from 'react-document-title'
import { connect } from 'react-redux'
import { openNewSimulationModal } from '../actions/modals/simulations'
import { fetchAuthorizationsOfCurrentUser } from '../actions/users'
import AppNavbar from '../components/navigation/AppNavbar'
import SimulationFilterPanel from '../components/simulations/FilterPanel'
import NewSimulationModal from '../containers/modals/NewSimulationModal'
import NewSimulationButtonContainer from '../containers/simulations/NewSimulationButtonContainer'
import VisibleSimulationList from '../containers/simulations/VisibleSimulationAuthList'

class SimulationsContainer extends React.Component {
    componentDidMount() {
        this.props.fetchAuthorizationsOfCurrentUser()
    }

    render() {
        return (
            <DocumentTitle title="My Simulations - OpenDC">
                <div className="full-height">
                    <AppNavbar inSimulation={false} fullWidth={false} />
                    <div className="container text-page-container full-height">
                        <SimulationFilterPanel />
                        <VisibleSimulationList />
                        <NewSimulationButtonContainer />
                    </div>
                    <NewSimulationModal />
                </div>
            </DocumentTitle>
        )
    }
}

const mapDispatchToProps = (dispatch) => {
    return {
        fetchAuthorizationsOfCurrentUser: () => dispatch(fetchAuthorizationsOfCurrentUser()),
        openNewSimulationModal: () => dispatch(openNewSimulationModal()),
    }
}

const Simulations = connect(undefined, mapDispatchToProps)(SimulationsContainer)

export default Simulations