blob: f65982efa7c7f50c8fc76af1dd310d918937850b (
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
|
import { connect } from 'react-redux'
import TopologyListComponent from '../../../../components/app/sidebars/project/TopologyListComponent'
import { setCurrentTopology } from '../../../../actions/topology/building'
import { openNewTopologyModal } from '../../../../actions/modals/topology'
import { withRouter } from 'react-router-dom'
import { getState } from '../../../../util/state-utils'
import { deleteScenario } from '../../../../actions/scenarios'
const mapStateToProps = (state) => {
let topologies = state.objects.project[state.currentProjectId]
? state.objects.project[state.currentProjectId].topologyIds.map((t) => state.objects.topology[t])
: []
if (topologies.filter((t) => !t).length > 0) {
topologies = []
}
return {
currentTopologyId: state.currentTopologyId,
topologies,
}
}
const mapDispatchToProps = (dispatch, ownProps) => {
return {
onChooseTopology: async (id) => {
dispatch(setCurrentTopology(id))
const state = await getState(dispatch)
ownProps.history.push(`/projects/${state.currentProjectId}`)
},
onNewTopology: () => {
dispatch(openNewTopologyModal())
},
onDeleteTopology: async (id) => {
if (id) {
const state = await getState(dispatch)
dispatch(deleteScenario(id))
dispatch(setCurrentTopology(state.objects.project[state.currentProjectId].topologyIds[0]))
ownProps.history.push(`/projects/${state.currentProjectId}`)
}
},
}
}
const TopologyListContainer = withRouter(connect(mapStateToProps, mapDispatchToProps)(TopologyListComponent))
export default TopologyListContainer
|