blob: 38047064eb403256c0487969203eb17612b367c7 (
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
import React from "react";
import {Group, Layer, Stage} from "react-konva";
import jQuery from "../../util/jquery";
import Backdrop from "./elements/Backdrop";
import GridGroup from "./groups/GridGroup";
import RoomGroup from "./groups/RoomGroup";
import {MAP_SIZE_IN_PIXELS} from "./MapConstants";
class MapStage extends React.Component {
state = {
width: 600,
height: 400
};
componentWillMount() {
this.updateDimensions();
}
componentDidMount() {
window.addEventListener("resize", this.updateDimensions.bind(this));
}
componentWillUnmount() {
window.removeEventListener("resize", this.updateDimensions.bind(this));
}
updateDimensions() {
this.setState({width: jQuery(window).width(), height: jQuery(window).height()});
}
dragBoundHandler(pos) {
return {
x: pos.x > 0 ? 0 :
(pos.x < -MAP_SIZE_IN_PIXELS + this.state.width ? -MAP_SIZE_IN_PIXELS + this.state.width : pos.x),
y: pos.y > 0 ? 0 :
(pos.y < -MAP_SIZE_IN_PIXELS + this.state.height ? -MAP_SIZE_IN_PIXELS + this.state.height : pos.y)
}
}
render() {
return (
<Stage width={this.state.width} height={this.state.height}>
<Layer>
<Group draggable={true} dragBoundFunc={this.dragBoundHandler.bind(this)}>
<Backdrop/>
<RoomGroup/>
<GridGroup/>
</Group>
</Layer>
</Stage>
)
}
}
export default MapStage;
|