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
|
import { connect } from 'react-redux'
import ChangeTopologyModalComponent from '../../components/modals/custom-components/ChangeTopologyModalComponent'
import { closeChangeTopologyModal } from '../../actions/modals/topology'
import { addTopology, deleteTopology } from '../../actions/topologies'
import { setCurrentTopology } from '../../actions/topology/building'
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 {
show: state.modals.changeTopologyModalVisible,
currentTopologyId: state.currentTopologyId,
topologies,
}
}
const mapDispatchToProps = dispatch => {
return {
onChooseTopology: (id) => {
dispatch(
setCurrentTopology(id),
)
dispatch(closeChangeTopologyModal())
},
onCreateTopology: (name) => {
if (name) {
dispatch(
addTopology({ name, rooms: [] }),
)
}
dispatch(closeChangeTopologyModal())
},
onDuplicateTopology: (name) => {
if (name) {
// TODO different handling here
dispatch(
addTopology({ name, rooms: [] }),
)
}
dispatch(closeChangeTopologyModal())
},
onDeleteTopology: (id) => {
if (id) {
dispatch(
deleteTopology(id),
)
}
},
onCancel: () => {
dispatch(closeChangeTopologyModal())
},
}
}
const ChangeTopologyModal = connect(mapStateToProps, mapDispatchToProps)(
ChangeTopologyModalComponent,
)
export default ChangeTopologyModal
|