source: imaps-frontend/src/scripts/shapes/InfoPin.js@ 0c6b92a

main
Last change on this file since 0c6b92a was 0c6b92a, checked in by stefan toskovski <stefantoska84@…>, 5 weeks ago

Pred finalna verzija

  • Property mode set to 100644
File size: 2.1 KB
RevLine 
[0c6b92a]1
[d565449]2import { _registerNode } from "konva/lib/Global";
[0c6b92a]3import MapNode from "../base/MapNode.js";
4import {node} from "prop-types";
5import draw from "../../pages/Draw/Draw.jsx";
6export default class InfoPin extends MapNode {
7 constructor(attrs,id) {
8 attrs.snap = false;
[d565449]9 super(
10 {
[0c6b92a]11 x: attrs.position.x,
12 y: attrs.position.y,
13 radiusX: attrs.blockSize * 0.5,
14 radiusY: attrs.blockSize * 0.7,
15 tailHeight: attrs.blockSize * 1.2,
16 fill: "#f60000",
[d565449]17 stroke: "#1b1b1b",
[0c6b92a]18 strokeWidth: 1,
[d565449]19 draggable: true,
20 name: "mapObj",
21 },
[0c6b92a]22 attrs.layer,
23 attrs.blockSize,
24 attrs.snap
[d565449]25 );
26
27 this.id = id;
[0c6b92a]28 this.eventName = "openPinModalEvent";
29 this.floorNum = attrs.floorNum;
[d565449]30
31 this.type = "InfoPin";
32 this._info = {
[0c6b92a]33 name: `Pin${id} [${this.floorNum}F]`,
[d565449]34 selectedPins: [],
35 description: "",
36 };
37
38 this.on("mouseover", () => {
[0c6b92a]39 this.fill("#FFD700");
[d565449]40 });
41 this.on("mouseout", () => {
[0c6b92a]42 this.fill("#f60000");
[d565449]43 });
44
[0c6b92a]45
[d565449]46 this.initText();
47 }
48 _sceneFunc(context, shape) {
[0c6b92a]49 const { radiusX, radiusY, tailHeight } = this.attrs; // attrs od konva
[d565449]50
51 context.beginPath();
52 context.ellipse(0, 0, radiusX, radiusY, 0, 0, Math.PI * 2);
53 context.closePath();
54 context.fillStrokeShape(shape);
55
56 context.beginPath();
57 context.moveTo(-radiusX, radiusY);
58 context.lineTo(0, radiusY + tailHeight);
59 context.lineTo(radiusX, radiusY);
60 context.closePath();
61
62 context.fillStrokeShape(shape);
63 }
64
[0c6b92a]65
[d565449]66 loadInfo(attrs) {
67 this.info.name = attrs.obj_name;
68 this.info.selectedPins = attrs.connected_pins;
69 this.info.description = attrs.description;
[0c6b92a]70 this.floorNum = attrs.floor_num
[d565449]71 }
72
73 saveShapeDetails() {
74 this.setAttr("obj_name", this.info.name);
75 this.setAttr("connected_pins", this.info.selectedPins);
76 this.setAttr("description", this.info.description);
[0c6b92a]77 this.setAttr("floor_num",this.floorNum)
[d565449]78 console.log(this.info, "vnatre vo info");
79 }
[0c6b92a]80
81 connect(node, draw = true) {
82 if(this.floorNum !== node.floorNum) return;
83 super.connect(node)
84 }
[d565449]85}
86
87InfoPin.prototype.className = "InfoPin";
88_registerNode(InfoPin);
Note: See TracBrowser for help on using the repository browser.