diff options
| author | Georgios Andreadis <g.andreadis@student.tudelft.nl> | 2017-09-03 17:53:03 +0200 |
|---|---|---|
| committer | Georgios Andreadis <g.andreadis@student.tudelft.nl> | 2017-09-23 10:05:56 +0200 |
| commit | 81e517002bfdfbcd75109c562d890a27d190889b (patch) | |
| tree | d69171040b5b9bfd45bfa4a51427a2138ffe9ea4 /src/components/map/MapStage.js | |
| parent | 17ae0a3fafd806a5a533bf1d51a3ac708a8cf978 (diff) | |
Convert map movement to keyboard-based navigation
Diffstat (limited to 'src/components/map/MapStage.js')
| -rw-r--r-- | src/components/map/MapStage.js | 74 |
1 files changed, 50 insertions, 24 deletions
diff --git a/src/components/map/MapStage.js b/src/components/map/MapStage.js index 541df1d6..f3f38917 100644 --- a/src/components/map/MapStage.js +++ b/src/components/map/MapStage.js @@ -1,12 +1,13 @@ import React from "react"; import {Group, Layer, Stage} from "react-konva"; +import {Shortcuts} from "react-shortcuts"; import DatacenterContainer from "../../containers/map/DatacenterContainer"; import HoverTileLayer from "../../containers/map/layers/HoverTileLayer"; import jQuery from "../../util/jquery"; import {NAVBAR_HEIGHT} from "../navigation/Navbar"; import Backdrop from "./elements/Backdrop"; import GridGroup from "./groups/GridGroup"; -import {MAP_SIZE_IN_PIXELS} from "./MapConstants"; +import {MAP_MOVE_PIXELS_PER_EVENT, MAP_SIZE_IN_PIXELS} from "./MapConstants"; class MapStage extends React.Component { state = { @@ -39,12 +40,33 @@ class MapStage extends React.Component { this.setState({mouseX: mousePos.x, mouseY: mousePos.y}); } - dragBoundFunc(pos) { + handleShortcuts(action) { + switch (action) { + case "MOVE_LEFT": + this.moveWithDelta(MAP_MOVE_PIXELS_PER_EVENT, 0); + break; + case "MOVE_RIGHT": + this.moveWithDelta(-MAP_MOVE_PIXELS_PER_EVENT, 0); + break; + case "MOVE_UP": + this.moveWithDelta(0, MAP_MOVE_PIXELS_PER_EVENT); + break; + case "MOVE_DOWN": + this.moveWithDelta(0, -MAP_MOVE_PIXELS_PER_EVENT); + break; + default: + break; + } + } + + moveWithDelta(deltaX, deltaY) { const updatedPosition = { - 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) + x: this.state.x + deltaX > 0 ? 0 : + (this.state.x + deltaX < -MAP_SIZE_IN_PIXELS + this.state.width + ? -MAP_SIZE_IN_PIXELS + this.state.width : this.state.x + deltaX), + y: this.state.y + deltaY > 0 ? 0 : + (this.state.y + deltaY < -MAP_SIZE_IN_PIXELS + this.state.height + ? -MAP_SIZE_IN_PIXELS + this.state.height : this.state.y + deltaY) }; this.setState(updatedPosition); @@ -54,24 +76,28 @@ class MapStage extends React.Component { render() { return ( - <Stage ref={(stage) => {this.stage = stage;}} - width={this.state.width} - height={this.state.height} - onMouseMove={this.updateMousePosition.bind(this)}> - <Layer> - <Group draggable={true} dragBoundFunc={this.dragBoundFunc.bind(this)}> - <Backdrop/> - <DatacenterContainer/> - <GridGroup/> - </Group> - </Layer> - <HoverTileLayer - mainGroupX={this.state.x} - mainGroupY={this.state.y} - mouseX={this.state.mouseX} - mouseY={this.state.mouseY} - /> - </Stage> + <Shortcuts name="MAP" handler={this.handleShortcuts.bind(this)} targetNodeSelector="body"> + <Stage + ref={(stage) => {this.stage = stage;}} + width={this.state.width} + height={this.state.height} + onMouseMove={this.updateMousePosition.bind(this)} + > + <Layer> + <Group x={this.state.x} y={this.state.y}> + <Backdrop/> + <DatacenterContainer/> + <GridGroup/> + </Group> + </Layer> + <HoverTileLayer + mainGroupX={this.state.x} + mainGroupY={this.state.y} + mouseX={this.state.mouseX} + mouseY={this.state.mouseY} + /> + </Stage> + </Shortcuts> ) } } |
