Changeset 79a0317 for imaps-frontend/src/scripts/main
- Timestamp:
- 01/21/25 03:08:24 (3 days ago)
- Branches:
- main
- Parents:
- 0c6b92a
- Location:
- imaps-frontend/src/scripts/main
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
imaps-frontend/src/scripts/main/MapBuilder.js
r0c6b92a r79a0317 21 21 22 22 // TODO AKO DRAGNIT NEKOJ OD POCETOK NA STAGE POZICIIVE KE SA ZEZNAT 23 // TODO jwt vo cookie24 23 // TODO placed shape i mouseMoveHandler da ne callback ( da ne vrakjat funkcija) 25 24 // TODO text na top layer sekogas … … 35 34 this.textLayer = new Konva.Layer(); 36 35 this.gridLayer.listening(false); 36 37 this.isDrawEventBound = false; 37 38 38 39 … … 96 97 setupEventListeners() { 97 98 document.getElementById("shapeOptions").addEventListener("click", this.selectShape.bind(this)); 98 window.addEventListener("keydown", this.handleExitSelection.bind(this));99 window.addEventListener("keydown", this.handleDelete.bind(this));100 window.addEventListener("keydown", this.rotateShapesBy90Deg.bind(this));101 window.addEventListener("keydown", this.toggleEfficientDrawingMode.bind(this));99 // window.addEventListener("keydown", this.handleExitSelection.bind(this)); 100 // window.addEventListener("keydown", this.handleDelete.bind(this)); 101 // window.addEventListener("keydown", this.rotateShapesBy90Deg.bind(this)); 102 // window.addEventListener("keydown", this.toggleEfficientDrawingMode.bind(this)); 102 103 window.addEventListener("resize", this.handleResize.bind(this)); 103 104 … … 107 108 this.boundEfficientDrawingModeEventListener = this.toggleEfficientDrawingMode.bind(this); 108 109 109 //this.attachKeyPressEventListeners();110 this.attachKeyPressEventListeners(); 110 111 111 112 this.stage.on("mousedown touchstart", this.handleMouseDown.bind(this)); … … 119 120 120 121 detachKeyPressEventListeners() { 122 console.log("DETACH") 121 123 window.removeEventListener("keydown", this.boundEscapeEventListener); 122 124 window.removeEventListener("keydown", this.boundDeleteEventListener); … … 126 128 127 129 attachKeyPressEventListeners() { 130 console.log("ATTACH") 128 131 window.addEventListener("keydown", this.boundEscapeEventListener); 129 132 window.addEventListener("keydown", this.boundDeleteEventListener); … … 269 272 let infoPin = Factory.createShape("InfoPin", attrs); 270 273 addEventHandling(infoPin, this, "dblclick"); 271 //this.shapes.push(infoPin);272 274 ShapeRegistry.add(infoPin) 273 275 this.mainLayer.add(infoPin); … … 307 309 308 310 const placedObj = Factory.createShape(this.hoverObj.type, attrs); 311 309 312 if (!placedObj) return; 310 313 … … 312 315 313 316 this.mainLayer.add(placedObj); 314 //this.shapes.push(placedObj);315 console.log("VO PLACED SHAEPS WALL ZITI SE: " + placedObj.className);316 317 ShapeRegistry.add(placedObj); 317 318 addEventHandling(placedObj, this, "dblclick"); 318 319 this.mainLayer.draw(); 319 320 320 // site ovie func da se vo edna funkcija vo shape. 321 321 322 322 placedObj.displayName(this.textLayer); 323 323 placedObj.snapToGrid(); 324 placedObj.onPlace(); 324 325 325 326 triggerMapSave(); … … 328 329 this.stopDrawing(); 329 330 } 331 this.mainTransformer.nodes([]) 330 332 } 331 333 332 334 stopDrawing() { 333 this.mainTransformer.nodes([]); 334 if (this.hoverObj != null) this.hoverObj.remove(); 335 this.dragLayer.removeChildren(); 336 this.stage.off("mousemove", this.boundMouseMoveHandler); 337 this.stage.off("click", this.boundPlaceShapeHandler); 335 if(this.isDrawEventBound){ 336 this.mainTransformer.nodes([]); 337 if (this.hoverObj != null) this.hoverObj.remove(); 338 this.dragLayer.removeChildren(); 339 this.stage.off("mousemove", this.boundMouseMoveHandler); 340 this.stage.off("click", this.boundPlaceShapeHandler); 341 this.isDrawEventBound = false; 342 } 343 338 344 } 339 345 … … 365 371 this.dragLayer.add(this.hoverObj); 366 372 this.dragLayer.moveToTop(); 373 374 367 375 this.boundMouseMoveHandler = this.mouseMoveHandler.bind(this); 368 376 this.boundPlaceShapeHandler = this.placeShape.bind(this); 377 this.isDrawEventBound = true; 369 378 370 379 this.stage.on("mousemove", this.boundMouseMoveHandler); … … 374 383 selectShape(e) { 375 384 if (e.target.tagName === "LI") { 385 this.stopDrawing() 376 386 const shapeType = e.target.getAttribute("data-info"); 377 387 this.startDrawing(shapeType); 378 this.mainTransformer.nodes([]) ;388 this.mainTransformer.nodes([]) 379 389 } 380 390 } … … 464 474 465 475 saveShapeDetails() { 466 // this.shapes.forEach(shape => {467 // shape.saveShapeDetails();468 // console.log(shape.info);469 // });470 476 ShapeRegistry.saveDetails(); 471 477 console.log("thisflornum",this.floorNum) … … 478 484 } 479 485 480 getPayload(){481 this.saveShapeDetails();482 return {483 shapes: ShapeRegistry.getShapes(this.floorNum),484 roomTypes: JSON.stringify(this.roomTypes),485 mapName: this.mapName,486 floorNum: this.floorNum487 }488 }489 486 490 487 491 488 handleStageClick(e) { 492 489 if (this.selectionRectangle.visible()) { 490 console.log("STAGECLICK1") 493 491 return; 494 492 } 495 493 496 494 if (e.target === this.stage) { 495 console.log("STAGECLICK2") 497 496 this.mainTransformer.nodes([]); 498 497 return; … … 500 499 501 500 if (!e.target.hasName("mapObj")) { 501 console.log("STAGECLICK3") 502 502 return; 503 503 } … … 505 505 const metaPressed = e.evt.shiftKey || e.evt.ctrlKey || e.evt.metaKey; 506 506 const isSelected = this.mainTransformer.nodes().indexOf(e.target) >= 0; 507 507 508 508 509 if (!metaPressed && !isSelected) { … … 527 528 } 528 529 529 getRoomTypes() {530 return this.roomTypes;531 }532 533 getRooms() {534 return this.getShapeInfoByType("Room");535 }536 537 getPins() {538 return this.getShapeInfoByType("InfoPin");539 }540 541 getEntrances() {542 return this.getShapeInfoByType("Entrance");543 }544 545 546 547 getShapeInfoByType(type) {548 return ShapeRegistry.getShapes(this.floorNum).filter((shape) => shape.className === type).map((shape) => shape.info);549 }550 551 530 552 531 drawConnection(node1Name, node2Name) { 553 532 554 533 ShapeRegistry.drawConnection(node1Name,node2Name); 555 }556 557 getNodeByName(name) {558 return ShapeRegistry.getShapes(this.floorNum).filter(shape => shape instanceof MapNode && shape.info.name === name)[0];559 534 } 560 535 … … 571 546 } 572 547 573 isMainEntranceSelected() {574 console.log(this.getEntrances().forEach((en) => console.log(en.isMainEntrance, "asdsad")));575 576 let hasMainEntrance = false;577 578 this.getEntrances().forEach((entrance) => {579 if (entrance.isMainEntrance === true) hasMainEntrance = true;580 });581 582 return hasMainEntrance;583 584 }585 548 586 549 clearMap() { … … 653 616 this.mainLayer.add(this.selectionRectangle); 654 617 655 ShapeRegistry.getShapes(this.floorNum).forEach((shape) => shape.displayName(this.textLayer)); 618 ShapeRegistry.getShapes(this.floorNum).forEach((shape) => { 619 shape.displayName(this.textLayer); 620 if(shape.className === "Entrance"){ 621 shape.setHighlight(); 622 } 623 }); 656 624 } 657 625 -
imaps-frontend/src/scripts/main/MapDisplay.js
r0c6b92a r79a0317 4 4 import {zoomStage} from "../util/zoomStage.js"; 5 5 import {addEventHandling} from "../util/addEventHandling.js"; 6 import ShapeRegistry from "../util/ShapeRegistry.js"; 6 7 import triggerNavigate from "../util/triggerNavigate.js"; 7 8 import config from "../net/netconfig.js"; 9 import {dispatchCustomEvent} from "../util/dispatchCustomEvent.js"; 10 import { jsPDF } from "jspdf"; 11 8 12 9 13 export class MapDisplay { … … 18 22 }); 19 23 24 this.selectedRoom = { 25 id: 1, 26 name: "223", 27 type: "Laboratory", 28 image: 29 "", 30 description: "223 is a laboratory with a capacity of 40 people", 31 }; 32 this.toggleSearch = false; 33 20 34 this.shapes = []; 21 35 this.roomTypes = []; … … 28 42 this.stage.add(this.textLayer); 29 43 44 45 this.cachedCanvases = []; 46 30 47 this.floorNum = floorNum; 31 48 … … 64 81 dsrData.forEach((shape) => { 65 82 if (shape.className !== "InfoPin") { 83 console.log("SHAPE ATTRS CREATE: " + JSON.stringify(shape.attrs)); 66 84 const renderedShape = Factory.createRenderedShape(shape.className, shape.attrs); 67 85 addEventHandling(renderedShape, this, "click"); 68 86 this.shapes.push(renderedShape); 87 console.log(renderedShape) 69 88 } 70 89 }); … … 78 97 } 79 98 80 81 82 99 loadMapN(floorData) { 83 100 if (floorData == null || floorData === "") return; … … 97 114 98 115 116 99 117 drawRouteNEW(nodes, offset = 0) { 100 118 … … 106 124 let buff = [nodes[idx].coordinates.x, nodes[idx].coordinates.y]; 107 125 108 109 126 ++idx; 110 127 … … 115 132 116 133 if (idx >= nodes.length){ 134 console.log("FLOOR NUM DISPLAY: " + this.floorNum) 135 let stageInfo = {stage:this.stage.clone(),floor:this.floorNum}; 136 this.cachedCanvases.push(stageInfo); 137 dispatchCustomEvent("navend",this.downloadURI) 117 138 return; 118 139 } … … 122 143 123 144 if (nextNode.floorNumber !== currentNode.floorNumber) { 145 let stageInfo = {stage:this.stage.clone(),floor:this.floorNum}; 146 this.cachedCanvases.push(stageInfo); 124 147 triggerNavigate(nodes, idx, nextNode.floorNumber, nextNode); 125 148 return; … … 131 154 const endY = nextNode.coordinates.y; 132 155 133 const numSegments = 1 2;156 const numSegments = 10; 134 157 135 158 const deltaX = (endX - startX) / numSegments; … … 157 180 clearInterval(interval); 158 181 idx++; 159 setTimeout(drawNextSegment, 150);182 setTimeout(drawNextSegment, 60); 160 183 } 161 }, 50);184 }, 30); 162 185 }; 163 186 164 187 drawNextSegment(); 165 188 } 166 167 168 189 169 190 initializeRoomTypes() { … … 173 194 } 174 195 175 getRoomTypes() {176 return this.roomTypes;177 }178 179 180 getShapeByName(name){181 return this.shapes.find(shape => shape.info.name === name)182 }183 184 196 getShapeByType(type) { 185 197 return this.shapes.filter((shape) => shape.class === type) 186 }187 188 toggleSearchRoom() {189 this.toggleSearch = !this.toggleSearch;190 198 } 191 199 … … 196 204 } 197 205 198 getMainEntrance() { 199 return this.shapes.filter(shape => shape.class === "Entrance").filter(el => el.info.isMainEntrance === true)[0]; 200 } 201 202 setFilter(filter) { 206 downloadURI(uri, name) { 207 let link = document.createElement('a'); 208 link.download = name; 209 link.href = uri; 210 document.body.appendChild(link); 211 link.click(); 212 document.body.removeChild(link); 213 } 214 215 216 getRouteImages(mapDetails = { mapName: "mapName", from: "from", to: "to" }) { 217 218 const pdf = new jsPDF("p", "mm", "a4"); 219 const pageWidth = pdf.internal.pageSize.getWidth(); 220 const pageHeight = pdf.internal.pageSize.getHeight(); 221 const margin = 10; 222 let yOffset = margin; 223 224 const imagesData = []; 225 226 let minWidth = 800; 227 228 this.cachedCanvases.forEach((canvas, index) => { 229 console.log("CANVASL " + JSON.stringify(canvas.stage)) 230 let dsrStage = Konva.Node.create(canvas.stage, document.createElement("div")); 231 232 let minX = Infinity, minY = Infinity, maxX = -Infinity, maxY = -Infinity; 233 234 dsrStage.getLayers().forEach(layer => { 235 layer.getChildren().forEach(shape => { 236 const shapeX = shape.x(); 237 const shapeY = shape.y(); 238 const width = shape.width() * shape.scaleX(); 239 const height = shape.height() * shape.scaleY(); 240 241 minX = Math.min(minX, shapeX - shape.offsetX() * shape.scaleX()); 242 minY = Math.min(minY, shapeY - shape.offsetY() * shape.scaleY()); 243 maxX = Math.max(maxX, shapeX + width - shape.offsetX() * shape.scaleX()); 244 maxY = Math.max(maxY, shapeY + height - shape.offsetY() * shape.scaleY()); 245 }); 246 }); 247 248 let padding = 50; 249 250 const virtualWidth = maxX - minX + padding; 251 const virtualHeight = maxY - minY + padding; 252 253 const scaleDownFactor = Math.min(pageWidth / virtualWidth, pageHeight / virtualHeight); 254 255 dsrStage.size({ width: virtualWidth, height: virtualHeight }); 256 dsrStage.position({ x: -minX, y: -minY }); 257 dsrStage.batchDraw(); 258 259 let canvasImageURI = dsrStage.toDataURL({ 260 pixelRatio: 1 261 }); 262 263 imagesData.push(canvasImageURI); 264 console.log(`Generated Image ${index + 1}`); 265 }); 266 267 268 269 imagesData.forEach((imageURI, index) => { 270 const text = `Floor: ${this.cachedCanvases[index].floor}`; 271 pdf.text(text, margin, yOffset + 5); 272 273 const img = new Image(); 274 img.src = imageURI; 275 276 const maxWidth = pageWidth - 2 * margin; 277 const maxHeight = pageHeight - 2 * margin; 278 let imgWidth = maxWidth; 279 let imgHeight = maxHeight / 2 280 281 if (imgHeight > maxHeight) { 282 imgHeight = maxHeight; 283 imgWidth = (pageWidth * maxHeight) / pageHeight; 284 } 285 286 if (yOffset + imgHeight > pageHeight - margin) { 287 pdf.addPage(); 288 yOffset = margin; 289 } 290 291 pdf.addImage(imageURI, "PNG", margin, yOffset, imgWidth, imgHeight); 292 yOffset += imgHeight + 10; 293 }); 294 295 pdf.save(`${mapDetails.mapName}-${mapDetails.from}-->${mapDetails.to}.route.pdf`); 296 } 297 298 299 300 setFilter(filter) { 203 301 let rooms = this.getShapeByType("Room") 204 302 if (filter === "All") {
Note:
See TracChangeset
for help on using the changeset viewer.