From b3d834de7730f20e33461ee7963d73ed83fa5a11 Mon Sep 17 00:00:00 2001 From: Just van den Broecke Date: Mon, 17 Mar 2014 18:51:50 +0100 Subject: [PATCH] issue #230 - enhancing AddLayers GUI for Layer previews --- src/script/plugins/AddLayers.js | 24 +++++++++++++++------ src/script/plugins/LayerSource.js | 36 ++++++++++++++++++++----------- src/script/plugins/TMSSource.js | 27 +++++++++++++++++++---- src/script/plugins/WMSSource.js | 23 +++++++++++++++++--- src/theme/all.css | 7 ++++++ 5 files changed, 91 insertions(+), 26 deletions(-) diff --git a/src/script/plugins/AddLayers.js b/src/script/plugins/AddLayers.js index 36ea85bb..b94b8603 100644 --- a/src/script/plugins/AddLayers.js +++ b/src/script/plugins/AddLayers.js @@ -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` @@ -471,7 +471,11 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, { // {layer.url.params.LAYERS} var tplLayerURL ='{url}'; var tplLayerName ='{LAYERS}'; - 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 = ''; + var previewImage = ''; + var layerPreviewWidth = this.layerPreviewWidth, layerPreviewHeight = this.layerPreviewHeight; + var self = this; var tpl = '
' + '
{title}' + @@ -502,7 +506,7 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, { '' + '' + '' + '' + '' + @@ -531,7 +535,6 @@ gxp.plugins.AddLayers = Ext.extend(gxp.plugins.Tool, { '' + '
' + - '' + + '{previewImage}' + '

Name: {name}
Abstract: {abstract}

' + '
' + - '

' + '
'; tpl = new Ext.XTemplate(tpl); tpl.compile(); @@ -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 = ''; + } else { + data.previewImage = '
 
'; + } data.rowIndex = rowIndex; return tpl.apply(data); }} diff --git a/src/script/plugins/LayerSource.js b/src/script/plugins/LayerSource.js index 9570c3d1..7fe4adf5 100644 --- a/src/script/plugins/LayerSource.js +++ b/src/script/plugins/LayerSource.js @@ -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. @@ -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`` */ @@ -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. @@ -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. @@ -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. * @@ -80,7 +80,7 @@ gxp.plugins.LayerSource = Ext.extend(Ext.util.Observable, { this.target = target; this.createStore(); }, - + /** private: method[getMapProjection] * :returns: ``OpenLayers.Projection`` */ @@ -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 @@ -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. @@ -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`` * diff --git a/src/script/plugins/TMSSource.js b/src/script/plugins/TMSSource.js index 0b1c1ef7..0f907b3e 100644 --- a/src/script/plugins/TMSSource.js +++ b/src/script/plugins/TMSSource.js @@ -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. @@ -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 } @@ -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, @@ -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() }) }); @@ -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; } }); diff --git a/src/script/plugins/WMSSource.js b/src/script/plugins/WMSSource.js index 0fa7e0f6..8050cedc 100644 --- a/src/script/plugins/WMSSource.js +++ b/src/script/plugins/WMSSource.js @@ -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. */ @@ -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({ diff --git a/src/theme/all.css b/src/theme/all.css index 15ec5afb..a2b1401a 100644 --- a/src/theme/all.css +++ b/src/theme/all.css @@ -607,6 +607,7 @@ div.olMap div.gx-overlay-playback { } /* START AddLayers CSS */ + .layercardgrid .x-grid3-row { background-color: #eeeeee; border-color:#eeeeee; @@ -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();