//= require geoblacklight/viewers/map GeoBlacklight.Viewer.Wms = GeoBlacklight.Viewer.Map.extend({ load: function() { this.options.bbox = L.bboxToBounds(this.data.mapBbox); this.map = L.map(this.element).fitBounds(this.options.bbox); this.map.addLayer(this.selectBasemap()); this.map.addLayer(this.overlay); if (this.data.available) { this.addPreviewLayer(); this.loadControls(); } else { this.addBoundsOverlay(this.options.bbox); } }, addPreviewLayer: function() { var _this = this; var wmsLayer = L.tileLayer.wms(this.data.url, { layers: this.data.layerId, format: 'image/png', transparent: true, tiled: true, CRS: 'EPSG:3857', opacity: this.options.opacity, detectRetina: _this.detectRetina() }); this.overlay.addLayer(wmsLayer); this.setupInspection(); }, setupInspection: function() { var _this = this; this.map.on('click', function(e) { spinner = '
Inspecting
'; $('.attribute-table-body').replaceWith(spinner); var wmsoptions = { URL: _this.data.url, LAYERS: _this.data.layerId, BBOX: _this.map.getBounds().toBBoxString(), WIDTH: $('#map').width(), HEIGHT: $('#map').height(), QUERY_LAYERS: _this.data.layerId, X: Math.round(e.containerPoint.x), Y: Math.round(e.containerPoint.y) }; $.ajax({ type: 'POST', url: '/wms/handle', beforeSend: function(xhr) { xhr.setRequestHeader('X-CSRF-Token', Rails.csrfToken()); }, data: wmsoptions, success: function(data) { if (data.hasOwnProperty('error') || data.values.length === 0) { $('.attribute-table-body').html('Could not find that feature'); return; } var html = $(''); $.each(data.values, function(i, val) { html.append('' + val[0] + '' + GeoBlacklight.Util.linkify(val[1]) + ''); }); $('.attribute-table-body').replaceWith(html); }, fail: function(error) { console.log(error); } }); }); } });