/**
## Mapview.locate()
@module /mapview/locate
@param {Object} params
The params object argument.
*/
export default function (params) {
this._locate =
this._locate ||
Object.assign(
{
icon: {
svg: `${this.host}/icons/locator.svg`,
scale: 0.05,
},
feature: new ol.Feature({
geometry: new ol.geom.Point([0, 0]),
}),
},
params || {},
);
this._locate.active = !this._locate.active;
// Create the geolocation marker if it doesn't exist yet.
if (!this._locate.L) {
this._locate.L = new ol.layer.Vector({
source: new ol.source.Vector({
features: [this._locate.feature],
}),
zIndex: 999,
style: mapp.utils.style({
icon: this._locate.icon,
}),
});
}
// Remove the geolocation marker if locate is not active.
if (!this._locate.active) {
this.Map.removeLayer(this._locate.L);
return;
}
this.Map.addLayer(this._locate.L);
mapp.utils.getCurrentPosition((pos) => {
const coords = ol.proj.fromLonLat([
parseFloat(pos.coords.longitude),
parseFloat(pos.coords.latitude),
]);
this._locate.feature.getGeometry().setCoordinates(coords);
// Fly to pos_ll and set flyTo to false to prevent map tracking.
this.Map.getView().animate({
center: coords,
zoom: this.locale.maxZoom,
});
});
}