To have the same path (starting with `ol/`, without `.js`) as in the documentation. The support was added in the webpack config in #8928
73 lines
1.5 KiB
JavaScript
73 lines
1.5 KiB
JavaScript
import Map from 'ol/Map';
|
|
import Overlay from 'ol/Overlay';
|
|
import View from 'ol/View';
|
|
import {toStringHDMS} from 'ol/coordinate';
|
|
import TileLayer from 'ol/layer/Tile';
|
|
import {toLonLat} from 'ol/proj';
|
|
import TileJSON from 'ol/source/TileJSON';
|
|
|
|
|
|
/**
|
|
* Elements that make up the popup.
|
|
*/
|
|
const container = document.getElementById('popup');
|
|
const content = document.getElementById('popup-content');
|
|
const closer = document.getElementById('popup-closer');
|
|
|
|
|
|
/**
|
|
* Create an overlay to anchor the popup to the map.
|
|
*/
|
|
const overlay = new Overlay({
|
|
element: container,
|
|
autoPan: true,
|
|
autoPanAnimation: {
|
|
duration: 250
|
|
}
|
|
});
|
|
|
|
|
|
/**
|
|
* Add a click handler to hide the popup.
|
|
* @return {boolean} Don't follow the href.
|
|
*/
|
|
closer.onclick = function() {
|
|
overlay.setPosition(undefined);
|
|
closer.blur();
|
|
return false;
|
|
};
|
|
|
|
|
|
/**
|
|
* Create the map.
|
|
*/
|
|
const map = new Map({
|
|
layers: [
|
|
new TileLayer({
|
|
source: new TileJSON({
|
|
url: 'https://api.tiles.mapbox.com/v3/mapbox.natural-earth-hypso-bathy.json?secure',
|
|
crossOrigin: 'anonymous'
|
|
})
|
|
})
|
|
],
|
|
overlays: [overlay],
|
|
target: 'map',
|
|
view: new View({
|
|
center: [0, 0],
|
|
zoom: 2
|
|
})
|
|
});
|
|
|
|
|
|
/**
|
|
* Add a click handler to the map to render the popup.
|
|
*/
|
|
map.on('singleclick', function(evt) {
|
|
const coordinate = evt.coordinate;
|
|
const hdms = toStringHDMS(toLonLat(coordinate));
|
|
|
|
content.innerHTML = '<p>You clicked here:</p><code>' + hdms +
|
|
'</code>';
|
|
overlay.setPosition(coordinate);
|
|
});
|