Skip to content

Commit

Permalink
issue planetfederal#230 - enhancing AddLayers GUI for Layer previews
Browse files Browse the repository at this point in the history
  • Loading branch information
justb4 committed Mar 17, 2014
1 parent 2c54b6e commit b3d834d
Show file tree
Hide file tree
Showing 5 changed files with 91 additions and 26 deletions.
24 changes: 17 additions & 7 deletions src/script/plugins/AddLayers.js
Original file line number Diff line number Diff line change
Expand Up @@ -235,17 +235,17 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, {
*/
layerGridHeight: 300,

/** api: config[layerCardLegendWidth]
/** api: config[layerPreviewWidth]
* ``Number``
* Width of the legend image inside the Layer card (``templatedLayerGrid`` must be true).
*/
layerCardLegendWidth: 20,
layerPreviewWidth: 20,

/** api: config[layerCardLegendHeight]
/** api: config[layerPreviewHeight]
* ``Number``
* Height of the legend image inside the Layer card (``templatedLayerGrid`` must be true).
*/
layerCardLegendHeight: 20,
layerPreviewHeight: 20,

/** private: property[selectedSource]
* :class:`gxp.plugins.LayerSource`
Expand Down Expand Up @@ -471,7 +471,11 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, {
// {layer.url.params.LAYERS}
var tplLayerURL ='<tpl for="."><tpl for="layer">{url}</tpl></tpl>';
var tplLayerName ='<tpl for="."><tpl for="layer"><tpl for="params">{LAYERS}</tpl></tpl></tpl>';
var tplReqURL = tplLayerURL +'REQUEST=GetLegendGraphic&VERSION=1.0.0&FORMAT=image/png&WIDTH='+ this.layerCardLegendWidth +'&HEIGHT='+ this.layerCardLegendHeight +'&LAYER=' + tplLayerName;
var tplReqURL = tplLayerURL +'REQUEST=GetLegendGraphic&VERSION=1.0.0&FORMAT=image/png&WIDTH='+ this.layerPreviewWidth +'&HEIGHT='+ this.layerPreviewHeight +'&LAYER=' + tplLayerName;
// var previewImage = '<img class="layerpreview" width="'+ this.layerPreviewWidth +'" height="'+ this.layerPreviewHeight + '" src="' + tplReqURL +'">';
var previewImage = '<img class="layerpreview" width="'+ this.layerPreviewWidth +'" height="'+ this.layerPreviewHeight + '" src="{previewImage}">';
var layerPreviewWidth = this.layerPreviewWidth, layerPreviewHeight = this.layerPreviewHeight;
var self = this;

var tpl = '<div class="layercard">' +
'<div class="meta_title">{title}' +
Expand Down Expand Up @@ -502,7 +506,7 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, {
'<table cellspacing="2" cellpadding="2">' +
'<tr>' +
'<td style="vertical-align:middle;">' +
'<img class="layerpreview" width="'+ this.layerCardLegendWidth +'" height="'+ this.layerCardLegendHeight + '" src="' + tplReqURL +'">' +
'{previewImage}' +
'</td>' +
'<td style="vertical-align:top; white-space: normal!important;"><p style="margin-top:4px;"><strong>Name: </strong>{name}<br><strong>Abstract: </strong>{abstract}</p></td>' +
'</tr>' +
Expand Down Expand Up @@ -531,7 +535,6 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, {
'</tbody>' +
'</table>' +
'</div>' +
'<p></p>' +
'</div>';
tpl = new Ext.XTemplate(tpl);
tpl.compile();
Expand All @@ -544,6 +547,13 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, {
renderer: function (value, metaData, record, rowIndex, colIndex, view) {
var data = record.data;
data.id = record.id;
var source = self.target.layerSources[record.store.sourceId];
var previewImageURL = source.getPreviewImageURL(record, layerPreviewWidth, layerPreviewHeight);
if (previewImageURL) {
data.previewImage = '<img class="layerpreview" onerror="this.style.display=\'none\'" width="'+ layerPreviewWidth +'" height="'+ layerPreviewHeight + '" src="' + previewImageURL + '">';
} else {
data.previewImage = '<div style="width:' + layerPreviewHeight + 'px; height:'+ layerPreviewHeight + 'px" class="preview-notavailable">&nbsp;</div>';
}
data.rowIndex = rowIndex;
return tpl.apply(data);
}}
Expand Down
36 changes: 24 additions & 12 deletions src/script/plugins/LayerSource.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/**
* Copyright (c) 2008-2011 The Open Planning Project
*
*
* Published under the GPL license.
* See https://github.com/opengeo/gxp/raw/master/license.txt for the full text
* of the license.
Expand All @@ -21,9 +21,9 @@ Ext.namespace("gxp.plugins");
* there, the viewer will create layers from it by looking at objects in
* the ``layers`` array of its ``map`` config option, calling the source's
* ``createLayerRecord`` method.
*/
*/
gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {

/** api: property[store]
* ``GeoExt.data.LayerStore``
*/
Expand All @@ -33,7 +33,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
* ``Object``
* The object that this plugin is plugged into.
*/

/** api: property[lazy]
* ``Boolean``. true when the source is ready, but its store hasn't
* been loaded yet (i.e. lazy source). Read-only.
Expand All @@ -45,19 +45,19 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
* up in the AddLayers dialog. Defaults to false.
*/
hidden: false,

/** api: property[title]
* ``String``
* A descriptive title for this layer source.
*/
title: "",

/** private: method[constructor]
*/
constructor: function(config) {
this.initialConfig = config;
Ext.apply(this, config);

this.addEvents(
/** api: event[ready]
* Fires when the layer source is ready for action.
Expand All @@ -70,7 +70,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
);
gxp.plugins.LayerSource.superclass.constructor.apply(this, arguments);
},

/** api: method[init]
* :arg target: ``Object`` The object initializing this plugin.
*
Expand All @@ -80,7 +80,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
this.target = target;
this.createStore();
},

/** private: method[getMapProjection]
* :returns: ``OpenLayers.Projection``
*/
Expand All @@ -90,7 +90,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
(projConfig && new OpenLayers.Projection(projConfig)) ||
new OpenLayers.Projection("EPSG:4326");
},

/** api: method[getProjection]
* :arg layerRecord: ``GeoExt.data.LayerRecord`` a record from this
* source's store
Expand All @@ -114,7 +114,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
mapProj;
return proj.equals(mapProj) ? mapProj : null;
},

/** api: method[createStore]
*
* Creates a store of layer records. Fires "ready" when store is loaded.
Expand Down Expand Up @@ -151,7 +151,19 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, {
selected: record.get("selected")
};
},


/** api: method[getPreviewImageURL]
* :arg record: :class:`GeoExt.data.LayerRecord`
* :arg width: :Number:image width
* :arg height: :Number:image height
* :returns: ``String``
*
* Create a preview image URL or encoded image for given record.
*/
getPreviewImageURL: function(record, width, height) {
return null;
},

/** api: method[getState]
* :returns: ``Object``
*
Expand Down
27 changes: 23 additions & 4 deletions src/script/plugins/TMSSource.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/**
* Copyright (c) 2008-2011 The Open Planning Project
*
*
* Published under the GPL license.
* See https://github.com/opengeo/gxp/raw/master/license.txt for the full text
* of the license.
Expand Down Expand Up @@ -80,7 +80,7 @@ gxp.data.TMSCapabilitiesReader = Ext.extend(Ext.data.DataReader, {
var layername = url.substring(url.indexOf(this.meta.version + '/') + 6);
records.push(new this.recordType({
layer: new OpenLayers.Layer.TMS(
tileMap.title,
tileMap.title,
(this.meta.baseUrl.indexOf(this.meta.version) !== -1) ? this.meta.baseUrl.replace(this.meta.version + '/', '') : this.meta.baseUrl, {
layername: layername
}
Expand All @@ -93,6 +93,9 @@ gxp.data.TMSCapabilitiesReader = Ext.extend(Ext.data.DataReader, {
}
}
}
if (records.length == 0) {
alert('No suitable TMS layers found, maybe a mismatch with your Map projection?')
}
return {
totalRecords: records.length,
success: true,
Expand Down Expand Up @@ -169,8 +172,8 @@ gxp.plugins.TMSSource = Ext.extend(gxp.plugins.LayerSource, {
method: "GET"
}),
reader: new gxp.data.TMSCapabilitiesReader({
baseUrl: this.url,
version: this.version,
baseUrl: this.url,
version: this.version,
mapProjection: this.getMapProjection()
})
});
Expand Down Expand Up @@ -211,6 +214,22 @@ gxp.plugins.TMSSource = Ext.extend(gxp.plugins.LayerSource, {
});
}
}
},

/** api: method[getPreviewImageURL]
* :arg record: :class:`GeoExt.data.LayerRecord`
* :arg width: :Number:image width
* :arg height: :Number:image height
* :returns: ``String``
*
* Create a preview image URL or encoded image for given record.
*/
getPreviewImageURL: function (record, width, height) {
var layerURL = record.data.tileMapUrl;
var tile = '/0/0/0.png';

var url = layerURL + tile;
return url;
}

});
Expand Down
23 changes: 20 additions & 3 deletions src/script/plugins/WMSSource.js
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,22 @@ gxp.plugins.WMSSource = Ext.extend(gxp.plugins.LayerSource, {
this.target.on("authorizationchange", this.onAuthorizationChange, this);
},

/** api: method[getPreviewImageURL]
* :arg record: :class:`GeoExt.data.LayerRecord`
* :arg width: :Number:image width
* :arg height: :Number:image height
* :returns: ``String``
*
* Create a preview image URL or encoded image for given record.
*/
getPreviewImageURL: function (record, width, height) {
var layerURL = record.data.layer.url;
var layerName = record.data.name;

var url = layerURL + 'REQUEST=GetLegendGraphic&VERSION=1.0.0&FORMAT=image/png&WIDTH=' + width + '&HEIGHT=' + height + '&LAYER=' + layerName;
return url;
},

/** private: method[onAuthorizationChange]
* Reload the store when the authorization changes.
*/
Expand Down Expand Up @@ -531,15 +547,16 @@ gxp.plugins.WMSSource = Ext.extend(gxp.plugins.LayerSource, {
CQL_FILTER: config.cql_filter
});

var singleTile = false;
// JvdB: default singleTile is true makes sense for most WMS Layers
var singleTile = true;
if ("tiled" in config) {
singleTile = !config.tiled;
} else {
} /* else {
// for now, if layer has a time dimension, use single tile
if (original.data.dimensions && original.data.dimensions.time) {
singleTile = true;
}
}
} */

layer.setName(config.title || layer.name);
layer.addOptions({
Expand Down
7 changes: 7 additions & 0 deletions src/theme/all.css
Original file line number Diff line number Diff line change
Expand Up @@ -607,6 +607,7 @@ div.olMap div.gx-overlay-playback {
}

/* START AddLayers CSS */

.layercardgrid .x-grid3-row {
background-color: #eeeeee;
border-color:#eeeeee;
Expand Down Expand Up @@ -693,6 +694,12 @@ div.olMap div.gx-overlay-playback {
/*height: 20px;*/
}

.layercard .preview-notavailable {
background-repeat: no-repeat;
/* No image available icon. Created via http://duri.me */
background-image: url()
}

.x-btn .gxp-icon-metadata, .x-menu-item .gxp-icon-metadata, .x-tree-node .gxp-icon-metadata {
/* tag_purple.png */
background-image: url();
Expand Down

0 comments on commit b3d834d

Please sign in to comment.