source: imaps-frontend/src/components/Modals/StairsModal/StairsModal.jsx@ 79a0317

main
Last change on this file since 79a0317 was 79a0317, checked in by stefan toskovski <stefantoska84@…>, 4 days ago

F4 Finalna Verzija

  • Property mode set to 100644
File size: 2.3 KB
Line 
1import React, {useState} from "react";
2import useModalState from "../Hooks/useModalState.jsx";
3import {useModalEvent} from "../Hooks/useModalEvent.jsx";
4import useConnections from "../Hooks/useConnections.jsx";
5import ModalNameField from "../Components/ModalNameField.jsx";
6
7import ModalDisplayConnections from "../Components/ModalDisplayConnections.jsx";
8import ModalDescriptionField from "../Components/ModalDescriptionField.jsx";
9import ModalSaveButton from "../Components/ModalSaveButton.jsx";
10import Modal from "../Components/Modal.jsx";
11import ModalSelectConnections2 from "../Components/ModalSelectConnections2.jsx";
12import ShapeRegistry from "../../../scripts/util/ShapeRegistry.js";
13import ShapeQuery from "../../../scripts/util/ShapeQuery.js";
14
15export default function StairsModal({map}){
16 const {
17 modalState: {isOpen,setIsOpen,setShape,shapeInfo,setShapeInfo},
18 handlers: {toggleModal,updateModalData,saveDetails}
19 } = useModalState(map);
20
21 const {
22 connectionState: {connections,setConnections},
23 handlers: {addConnection,removeConnection}
24 } = useConnections(map,shapeInfo,setShapeInfo)
25
26
27 useModalEvent((event) => {
28 const roomObj = event.detail.room;
29 setShape(roomObj);
30 setShapeInfo(roomObj.info);
31 console.log("stairs connections shape info: " + roomObj.info.selectedPins)
32 setConnections(roomObj.info.selectedPins || []);
33 setIsOpen(true);
34 console.log(roomObj.info.selectedPins, "Loaded pins on modal open");
35 event.detail.map.detachKeyPressEventListeners();
36 },"openStairsModalEvent")
37
38
39
40 return (
41
42 <Modal isOpen={isOpen} toggleModal={toggleModal} title={"Enter Stair Details"}>
43 <ModalNameField shapeInfo={shapeInfo} updateModalData={updateModalData} phtext={"Enter name of stairs"}/>
44 <ModalSelectConnections2
45 shapeInfo={shapeInfo}
46 updateModalData={updateModalData}
47 addConnection={addConnection}
48 availableShapes={ShapeQuery.findAllByType("Stairs")}
49 />
50 <ModalDisplayConnections connections={connections} removePinFromList={removeConnection}/>
51 <ModalDescriptionField shapeInfo={shapeInfo} updateModalData={updateModalData}/>
52 <ModalSaveButton saveDetails={saveDetails}/>
53 </Modal>
54 )
55}
Note: See TracBrowser for help on using the repository browser.