Skip to content

Commit

Permalink
Fixes #1171: zoom to layer tool in TOC (#1225)
Browse files Browse the repository at this point in the history
  • Loading branch information
mbarto authored Oct 27, 2016
1 parent 27a45b0 commit d665a56
Show file tree
Hide file tree
Showing 8 changed files with 99 additions and 2 deletions.
13 changes: 13 additions & 0 deletions web/client/components/TOC/DefaultLayer.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ var DefaultLayer = React.createClass({
settings: React.PropTypes.object,
propertiesChangeHandler: React.PropTypes.func,
onToggle: React.PropTypes.func,
onZoom: React.PropTypes.func,
onSettings: React.PropTypes.func,
style: React.PropTypes.object,
sortableStyle: React.PropTypes.object,
Expand All @@ -34,6 +35,7 @@ var DefaultLayer = React.createClass({
activateLegendTool: React.PropTypes.bool,
activateRemoveLayer: React.PropTypes.bool,
activateSettingsTool: React.PropTypes.bool,
activateZoomTool: React.PropTypes.bool,
settingsText: React.PropTypes.oneOfType([React.PropTypes.string, React.PropTypes.element]),
opacityText: React.PropTypes.oneOfType([React.PropTypes.string, React.PropTypes.element]),
saveText: React.PropTypes.oneOfType([React.PropTypes.string, React.PropTypes.element]),
Expand All @@ -52,10 +54,12 @@ var DefaultLayer = React.createClass({
sortableStyle: {},
propertiesChangeHandler: () => {},
onToggle: () => {},
onZoom: () => {},
onSettings: () => {},
activateRemoveLayer: false,
activateLegendTool: false,
activateSettingsTool: false,
activateZoomTool: false,
includeDeleteButtonInSettings: false,
modalOptions: {},
settingsOptions: {},
Expand Down Expand Up @@ -134,6 +138,15 @@ var DefaultLayer = React.createClass({
onClick={(node) => this.props.onToggle(node.id, node.expanded)}/>
);
}
if (this.props.activateZoomTool && this.props.node.bbox) {
tools.push(
<LayersTool key="toolzoom"
ref="target"
style={{"float": "right", cursor: "pointer"}}
glyph="search"
onClick={(node) => this.props.onZoom(node.bbox.bounds, node.bbox.crs)}/>
);
}
return tools;
},
render() {
Expand Down
32 changes: 32 additions & 0 deletions web/client/components/TOC/__tests__/DefaultLayer-test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,38 @@ describe('test DefaultLayer module component', () => {
expect(spy.calls.length).toBe(1);
});

it('tests zoom tool', () => {
const l = {
name: 'layer00',
title: 'Layer',
visibility: true,
storeIndex: 9,
type: 'wms',
bbox: {
crs: "EPSG:4326",
bounds: {
minx: 11.0,
maxx: 13.0,
miny: 43.0,
maxy: 44.0
}
}
};
const actions = {
onZoom: () => {}
};
let spy = expect.spyOn(actions, "onZoom");
const comp = ReactDOM.render(<Layer visibilityCheckType="checkbox" node={l} activateZoomTool={true} onZoom={actions.onZoom}/>,
document.getElementById("container"));
expect(comp).toExist();
const domNode = ReactDOM.findDOMNode(comp);
expect(domNode).toExist();
const tool = ReactDOM.findDOMNode(TestUtils.scryRenderedDOMComponentsWithClass(comp, "glyphicon")[1]);
expect(tool).toExist();
tool.click();
expect(spy.calls.length).toBe(1);
});

it('tests removelayer tool', () => {
const l = {
name: 'layer000',
Expand Down
10 changes: 9 additions & 1 deletion web/client/components/catalog/RecordItem.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,15 @@ const RecordItem = React.createClass({
visibility: true,
name: wms.params && wms.params.name,
title: this.props.record.title || (wms.params && wms.params.name),
boundingBox: this.props.record.boundingBox,
bbox: {
crs: this.props.record.boundingBox.crs,
bounds: {
minx: this.props.record.boundingBox.extent[0],
miny: this.props.record.boundingBox.extent[1],
maxx: this.props.record.boundingBox.extent[2],
maxy: this.props.record.boundingBox.extent[3]
}
},
links: this.getLinks(this.props.record),
params: params,
allowedSRS: allowedSRS
Expand Down
29 changes: 29 additions & 0 deletions web/client/components/catalog/__tests__/RecordItem-test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -190,4 +190,33 @@ describe('This test for RecordItem', () => {
button.click();
expect(actionsSpy.calls.length).toBe(1);
});
it('check add layer with bounding box', () => {
let actions = {
onLayerAdd: () => {

},
onZoomToExtent: () => {

}
};
let actionsSpy = expect.spyOn(actions, "onLayerAdd");
const item = ReactDOM.render((<ReactItem
record={sampleRecord}
onLayerAdd={actions.onLayerAdd}
/>), document.getElementById("container"));
expect(item).toExist();

const itemDom = ReactDOM.findDOMNode(item);
expect(itemDom).toExist();
expect(itemDom.className).toBe('record-item panel panel-default');
let button = TestUtils.findRenderedDOMComponentWithTag(
item, 'button'
);
expect(button).toExist();
button.click();
expect(actionsSpy.calls.length).toBe(1);
expect(actionsSpy.calls[0].arguments[0].bbox).toExist();
expect(actionsSpy.calls[0].arguments[0].bbox.crs).toExist();
expect(actionsSpy.calls[0].arguments[0].bbox.bounds).toExist();
});
});
6 changes: 5 additions & 1 deletion web/client/config.json
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,11 @@
"title": "Weather data",
"name": "nurc:Arc_Sample",
"group": "Meteo",
"format": "image/png"
"format": "image/png",
"bbox": {
"bounds": {"minx": -25.6640625, "miny": 26.194876675795218, "maxx": 48.1640625, "maxy": 56.80087831233043},
"crs": "EPSG:4326"
}
},
{
"type": "tileprovider",
Expand Down
1 change: 1 addition & 0 deletions web/client/plugins/Save.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,7 @@ const Save = React.createClass({
transparent: layer.transparent,
type: layer.type,
url: layer.url,
bbox: layer.bbox,
visibility: layer.visibility
};
});
Expand Down
1 change: 1 addition & 0 deletions web/client/plugins/SaveAs.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@ const SaveAs = React.createClass({
transparent: layer.transparent,
type: layer.type,
url: layer.url,
bbox: layer.bbox,
visibility: layer.visibility
};
});
Expand Down
9 changes: 9 additions & 0 deletions web/client/plugins/TOC.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ const {connect} = require('react-redux');
const {createSelector} = require('reselect');
const {changeLayerProperties, changeGroupProperties, toggleNode,
sortNode, showSettings, hideSettings, updateSettings, updateNode, removeNode} = require('../actions/layers');
const {zoomToExtent} = require('../actions/map');

const {groupsSelector} = require('../selectors/layers');

const LayersUtils = require('../utils/LayersUtils');
Expand Down Expand Up @@ -46,6 +48,7 @@ const LayerTree = React.createClass({
layerPropertiesChangeHandler: React.PropTypes.func,
onToggleGroup: React.PropTypes.func,
onToggleLayer: React.PropTypes.func,
onZoomToExtent: React.PropTypes.func,
onSort: React.PropTypes.func,
onSettings: React.PropTypes.func,
hideSettings: React.PropTypes.func,
Expand All @@ -54,6 +57,7 @@ const LayerTree = React.createClass({
removeNode: React.PropTypes.func,
activateRemoveLayer: React.PropTypes.bool,
activateLegendTool: React.PropTypes.bool,
activateZoomTool: React.PropTypes.bool,
activateSettingsTool: React.PropTypes.bool,
visibilityCheckType: React.PropTypes.string,
settingsOptions: React.PropTypes.object
Expand All @@ -64,10 +68,12 @@ const LayerTree = React.createClass({
layerPropertiesChangeHandler: () => {},
onToggleGroup: () => {},
onToggleLayer: () => {},
onZoomToExtent: () => {},
onSettings: () => {},
updateNode: () => {},
removeNode: () => {},
activateLegendTool: true,
activateZoomTool: true,
activateSettingsTool: true,
activateRemoveLayer: true,
visibilityCheckType: "checkbox",
Expand Down Expand Up @@ -96,6 +102,7 @@ const LayerTree = React.createClass({
<DefaultLayer
settingsOptions={this.props.settingsOptions}
onToggle={this.props.onToggleLayer}
onZoom={this.props.onZoomToExtent}
onSettings={this.props.onSettings}
propertiesChangeHandler={this.props.layerPropertiesChangeHandler}
hideSettings={this.props.hideSettings}
Expand All @@ -106,6 +113,7 @@ const LayerTree = React.createClass({
visibilityCheckType={this.props.visibilityCheckType}
activateRemoveLayer={this.props.activateRemoveLayer}
activateLegendTool={this.props.activateLegendTool}
activateZoomTool={this.props.activateZoomTool}
activateSettingsTool={this.props.activateSettingsTool}
settingsText={<Message msgId="layerProperties.windowTitle"/>}
opacityText={<Message msgId="opacity"/>}
Expand All @@ -126,6 +134,7 @@ const TOCPlugin = connect(tocSelector, {
onToggleLayer: LayersUtils.toggleByType('layers', toggleNode),
onSort: LayersUtils.sortUsing(LayersUtils.sortLayers, sortNode),
onSettings: showSettings,
onZoomToExtent: zoomToExtent,
hideSettings,
updateSettings,
updateNode,
Expand Down

0 comments on commit d665a56

Please sign in to comment.