summaryrefslogtreecommitdiff
path: root/src/containers/modals/EditRoomNameModal.js
blob: be6230d0abec26a2973a1a2475aa9f09a1310109 (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
import React from "react";
import {connect} from "react-redux";
import {closeEditRoomNameModal} from "../../actions/modals/topology";
import {editRoomName} from "../../actions/topology/room";
import TextInputModal from "../../components/modals/TextInputModal";

const EditRoomNameModalComponent = ({visible, previousName, callback}) => (
    <TextInputModal title="Edit room name"
                    label="Room name"
                    show={visible}
                    initialValue={previousName}
                    callback={callback}/>
);

const mapStateToProps = state => {
    return {
        visible: state.modals.editRoomNameModalVisible,
        previousName: state.interactionLevel.mode === "ROOM" ? state.objects.room[state.interactionLevel.roomId].name : "",
    };
};

const mapDispatchToProps = dispatch => {
    return {
        callback: (name) => {
            if (name) {
                dispatch(editRoomName(name));
            }
            dispatch(closeEditRoomNameModal());
        }
    };
};

const EditRoomNameModal = connect(
    mapStateToProps,
    mapDispatchToProps
)(EditRoomNameModalComponent);

export default EditRoomNameModal;