mirror of
https://github.com/netzmacht/contao-leaflet-maps.git
synced 2025-11-29 03:24:37 +01:00
Move L.Contao to libs directory.
This commit is contained in:
@@ -1,143 +0,0 @@
|
||||
L.Contao = L.Class.extend( {
|
||||
includes: L.Mixin.Events,
|
||||
|
||||
/**
|
||||
* The map registry.
|
||||
*/
|
||||
maps: {},
|
||||
|
||||
/**
|
||||
* The icons registry.
|
||||
*/
|
||||
icons: {},
|
||||
|
||||
/**
|
||||
* Initialize Contao leaflet integration.
|
||||
*/
|
||||
initialize: function() {
|
||||
L.Icon.Default.imagePath = 'assets/leaflet/libs/leaflet/images';
|
||||
},
|
||||
|
||||
/**
|
||||
* Add map to map registry.
|
||||
*
|
||||
* @param id The map id.
|
||||
* @param map The map object.
|
||||
*
|
||||
* @returns {L.Contao}
|
||||
*/
|
||||
addMap: function (id, map) {
|
||||
this.maps[id] = map;
|
||||
|
||||
this.fire('map:added', { id: id, map: map});
|
||||
|
||||
return this;
|
||||
},
|
||||
|
||||
/**
|
||||
* Get a map from the icon map. Returns null if not set.
|
||||
*
|
||||
* @param id The mapobject
|
||||
*
|
||||
* @returns {L.Map}|{*}
|
||||
*/
|
||||
getMap: function (id) {
|
||||
if (typeof (this.maps[id]) === 'undefined') {
|
||||
return null;
|
||||
}
|
||||
|
||||
return this.maps[id];
|
||||
},
|
||||
|
||||
/**
|
||||
* Add an icon to the icon registry.
|
||||
*
|
||||
* @param id The icon id.
|
||||
* @param icon The icon object.
|
||||
*
|
||||
* @returns {L.Contao}
|
||||
*/
|
||||
addIcon: function(id, icon) {
|
||||
this.icons[id] = icon;
|
||||
this.fire('icon:added', { id: id, icon: icon});
|
||||
|
||||
return this;
|
||||
},
|
||||
|
||||
/**
|
||||
* Load icon definitions.
|
||||
*
|
||||
* @param icons List of icon definitions.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
loadIcons: function(icons) {
|
||||
for (var i = 0; i < icons.length; i++) {
|
||||
var icon = L[icons[i].type](icons[i].options);
|
||||
this.addIcon(icons[i].id, icon);
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Get an icon by its id.
|
||||
*
|
||||
* @param id Icon id.
|
||||
*
|
||||
* @returns {L.Icon}|{L.DivIcon}|{*}
|
||||
*/
|
||||
getIcon: function(id) {
|
||||
if (typeof (this.icons[id]) === 'undefined') {
|
||||
return null;
|
||||
}
|
||||
|
||||
return this.icons[id];
|
||||
},
|
||||
|
||||
/**
|
||||
* Point to layer callback. Adds a geo json point to the layer.
|
||||
*
|
||||
* @param feature The geo json feature.
|
||||
* @param latlng The converted latlng.
|
||||
*
|
||||
* @returns {L.Marker}|{*}
|
||||
*/
|
||||
pointToLayer: function(feature, latlng) {
|
||||
var marker = L.marker(latlng, feature.properties.options);
|
||||
|
||||
if (feature.properties) {
|
||||
if (feature.properties.icon) {
|
||||
var icon = this.getIcon(feature.properties.icon);
|
||||
|
||||
if (icon) {
|
||||
marker.setIcon(icon);
|
||||
}
|
||||
}
|
||||
|
||||
this.bindPopupFromFeature(marker, feature);
|
||||
}
|
||||
|
||||
this.fire('marker:created', { marker: marker, feature: feature, latlng: latlng });
|
||||
|
||||
return marker;
|
||||
},
|
||||
|
||||
/**
|
||||
* Bind popup from feature definitions.
|
||||
*
|
||||
* It accepts popup or popupContent as property.
|
||||
*
|
||||
* @param obj The object
|
||||
* @param feature The geo json feature.
|
||||
*/
|
||||
bindPopupFromFeature: function (obj, feature) {
|
||||
if (feature.properties) {
|
||||
if (feature.properties.popup) {
|
||||
obj.bindPopup(feature.properties.popup);
|
||||
} else if (feature.properties.popupContent) {
|
||||
obj.bindPopup(feature.properties.popupContent);
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
window.ContaoLeaflet = new L.Contao();
|
||||
Reference in New Issue
Block a user