diff options
Diffstat (limited to 'src/containers/modals/EditRackNameModal.js')
| -rw-r--r-- | src/containers/modals/EditRackNameModal.js | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/containers/modals/EditRackNameModal.js b/src/containers/modals/EditRackNameModal.js new file mode 100644 index 00000000..e793f146 --- /dev/null +++ b/src/containers/modals/EditRackNameModal.js @@ -0,0 +1,39 @@ +import React from "react"; +import {connect} from "react-redux"; +import {closeEditRackNameModal} from "../../actions/modals/topology"; +import {editRackName} from "../../actions/topology"; +import TextInputModal from "../../components/modals/TextInputModal"; + +const EditRackNameModalComponent = ({visible, previousName, callback}) => ( + <TextInputModal title="Edit rack name" + label="Rack name" + show={visible} + initialValue={previousName} + callback={callback}/> +); + +const mapStateToProps = state => { + return { + visible: state.modals.editRackNameModalVisible, + previousName: state.interactionLevel.mode === "RACK" ? + state.objects.rack[state.objects.tile[state.interactionLevel.tileId].objectId].name : "", + }; +}; + +const mapDispatchToProps = dispatch => { + return { + callback: (name) => { + if (name) { + dispatch(editRackName(name)); + } + dispatch(closeEditRackNameModal()); + } + }; +}; + +const EditRackNameModal = connect( + mapStateToProps, + mapDispatchToProps +)(EditRackNameModalComponent); + +export default EditRackNameModal; |
