/**
* Copyright (c) 2000-present Liferay, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
*/
import MapBase from '@liferay/map-common/js/MapBase.es';
import {Config} from 'metal-state';
import OpenStreetMapDialog from './OpenStreetMapDialog.es';
import OpenStreetMapGeoJSON from './OpenStreetMapGeoJSON.es';
import OpenStreetMapGeocoder from './OpenStreetMapGeocoder.es';
import OpenStreetMapMarker from './OpenStreetMapMarker.es';
/**
* MapOpenStreetMap
* @review
*/
class MapOpenStreetMap extends MapBase {
/**
* Creates a new map using OpenStreetMap's API
* @param {Array} args List of arguments to be passed to State
* @review
*/
constructor(...args) {
super(...args);
MapBase.DialogImpl = OpenStreetMapDialog;
MapBase.GeocoderImpl = OpenStreetMapGeocoder;
MapBase.GeoJSONImpl = OpenStreetMapGeoJSON;
MapBase.MarkerImpl = OpenStreetMapMarker;
MapBase.SearchImpl = null;
this._map = null;
}
/**
* @inheritDoc
* @review
*/
_createMap(location, controlsConfig) {
const mapConfig = {
center: location,
layers: [L.tileLayer(this.tileURI)],
zoom: this.zoom,
};
const map = L.map(
document.querySelector(this.boundingBox),
Object.assign(mapConfig, controlsConfig)
);
if (this.data && this.data.features) {
const bounds = new L.LatLngBounds();
this.data.features.forEach((feature) =>
bounds.extend(
new L.LatLng(
feature.geometry.coordinates[1],
feature.geometry.coordinates[0]
)
)
);
map.fitBounds(bounds);
}
return map;
}
/**
* @inheritDoc
* @review
*/
addControl(control, position) {
const LeafLetControl = L.Control.extend({
onAdd() {
if (typeof control === 'string') {
control = document.querySelector(control);
}
return control;
},
options: {
position: MapOpenStreetMap.POSITION_MAP[position],
},
});
this._map.addControl(new LeafLetControl());
}
/**
* @inheritDoc
* @review
*/
getBounds() {
return this._map.getBounds();
}
/**
* @inheritDoc
* @review
*/
setCenter(location) {
if (this._map) {
this._map.panTo(location);
}
if (this._geolocationMarker) {
this._geolocationMarker.setPosition(location);
}
}
}
MapOpenStreetMap.CONTROLS_MAP = {
[MapBase.CONTROLS.ATTRIBUTION]: 'attributionControl',
[MapBase.CONTROLS.ZOOM]: 'zoomControl',
};
MapOpenStreetMap.POSITION_MAP = {
[MapBase.POSITION.BOTTOM]: 'bottomleft',
[MapBase.POSITION.BOTTOM_CENTER]: 'bottomleft',
[MapBase.POSITION.BOTTOM_LEFT]: 'bottomleft',
[MapBase.POSITION.BOTTOM_RIGHT]: 'bottomright',
[MapBase.POSITION.CENTER]: 'topleft',
[MapBase.POSITION.LEFT]: 'topleft',
[MapBase.POSITION.LEFT_BOTTOM]: 'bottomleft',
[MapBase.POSITION.LEFT_CENTER]: 'topleft',
[MapBase.POSITION.LEFT_TOP]: 'topleft',
[MapBase.POSITION.RIGHT]: 'bottomright',
[MapBase.POSITION.RIGHT_BOTTOM]: 'bottomright',
[MapBase.POSITION.RIGHT_CENTER]: 'bottomright',
[MapBase.POSITION.RIGHT_TOP]: 'topright',
[MapBase.POSITION.TOP]: 'topright',
[MapBase.POSITION.TOP_CENTER]: 'topright',
[MapBase.POSITION.TOP_LEFT]: 'topleft',
[MapBase.POSITION.TOP_RIGHT]: 'topright',
};
/**
* State definition.
* @type {!Object}
* @static
*/
MapOpenStreetMap.STATE = {
...MapBase.STATE,
/**
* Url used for fetching map tile information
* @type {string}
*/
tileURI: Config.string().value(
'//{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'
),
};
export default MapOpenStreetMap;
export {MapOpenStreetMap};