mirror of
https://github.com/netzmacht/contao-leaflet-maps.git
synced 2025-11-28 11:04:08 +01:00
Refactor overpass support using own implementation of overpass layer.
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -30,23 +30,31 @@ L.Map.include({
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this._dynamicBounds) {
|
if (this._dynamicBounds) {
|
||||||
options = {};
|
this.fitBounds(this._dynamicBounds, this.getBoundsOptions());
|
||||||
|
|
||||||
if (this.options.boundsPadding) {
|
|
||||||
options.padding = this.options.boundsPadding;
|
|
||||||
} else {
|
|
||||||
if (this.options.boundsPaddingTopLeft) {
|
|
||||||
options.paddingTopLeft = this.options.boundsPaddingTopLeft;
|
|
||||||
}
|
|
||||||
if (this.options.boundsPaddingBottomRight) {
|
|
||||||
options.paddingBottomRight = this.options.boundsPaddingBottomRight;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.fitBounds(this._dynamicBounds, options);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the bounds optons
|
||||||
|
* @returns {{}}
|
||||||
|
*/
|
||||||
|
getBoundsOptions: function () {
|
||||||
|
options = {};
|
||||||
|
|
||||||
|
if (this.options.boundsPadding) {
|
||||||
|
options.padding = this.options.boundsPadding;
|
||||||
|
} else {
|
||||||
|
if (this.options.boundsPaddingTopLeft) {
|
||||||
|
options.paddingTopLeft = this.options.boundsPaddingTopLeft;
|
||||||
|
}
|
||||||
|
if (this.options.boundsPaddingBottomRight) {
|
||||||
|
options.paddingBottomRight = this.options.boundsPaddingBottomRight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return options;
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Scan recursively for bounds in a layer and extend _dynamicBounds if any found.
|
* Scan recursively for bounds in a layer and extend _dynamicBounds if any found.
|
||||||
*
|
*
|
||||||
|
|||||||
215
assets/maps/src/OverpassLayer.js
Normal file
215
assets/maps/src/OverpassLayer.js
Normal file
@@ -0,0 +1,215 @@
|
|||||||
|
/**
|
||||||
|
* Get the bounds as overpass bbox string.
|
||||||
|
*
|
||||||
|
* @returns {string}
|
||||||
|
*/
|
||||||
|
L.LatLngBounds.prototype.toOverpassBBoxString = function () {
|
||||||
|
var a = this._southWest,
|
||||||
|
b = this._northEast;
|
||||||
|
|
||||||
|
return [a.lat, a.lng, b.lat, b.lng].join(",");
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implementation of the overpass layer. Heavily inspired by
|
||||||
|
* https://github.com/kartenkarsten/leaflet-layer-overpass.
|
||||||
|
*/
|
||||||
|
L.OverPassLayer = L.FeatureGroup.extend({
|
||||||
|
options: {
|
||||||
|
minZoom: 0,
|
||||||
|
endpoint: '//overpass-api.de/api/',
|
||||||
|
query: '(node(BBOX)[organic];node(BBOX)[second_hand];);out qt;'
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Initialize the layer.
|
||||||
|
*
|
||||||
|
* @param options
|
||||||
|
*/
|
||||||
|
initialize: function (options) {
|
||||||
|
L.Util.setOptions(this, options);
|
||||||
|
|
||||||
|
this.options.pointToLayer = this.pointToLayer;
|
||||||
|
this.options.onEachFeature = this.onEachFeature;
|
||||||
|
this.options.dynamicLoad = this.options.query.match(/BBOX/g) ? true : false;
|
||||||
|
|
||||||
|
this._layer = L.geoJson();
|
||||||
|
this._layers = {};
|
||||||
|
|
||||||
|
this.addLayer(this._layer);
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Refresh the data of the layer.
|
||||||
|
*
|
||||||
|
* TODO: Implement some caching.
|
||||||
|
*/
|
||||||
|
refreshData: function () {
|
||||||
|
if (this._map.getZoom() < this.options.minZoom) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var bounds = this._map.getBounds().toOverpassBBoxString();
|
||||||
|
var query = this.options.query.replace(/(BBOX)/g, bounds);
|
||||||
|
var url = this.options.endpoint + "interpreter?data=[out:json];" + query;
|
||||||
|
|
||||||
|
this._map.fire('dataloading', {layer: this});
|
||||||
|
|
||||||
|
this.request(url, function (error, response) {
|
||||||
|
var data = JSON.parse(response.response);
|
||||||
|
var features = osmtogeojson(data);
|
||||||
|
var layer = L.geoJson(features, {
|
||||||
|
pointToLayer: this.options.pointToLayer.bind(this),
|
||||||
|
onEachFeature: this.options.onEachFeature.bind(this)
|
||||||
|
});
|
||||||
|
|
||||||
|
this.addLayer(layer);
|
||||||
|
this.removeLayer(this._layer);
|
||||||
|
this._layer = layer;
|
||||||
|
|
||||||
|
if (this.options.boundsMode === 'extend' && layer.getBounds().isValid()) {
|
||||||
|
var bounds = this._map.getBounds();
|
||||||
|
bounds = bounds.extend(layer.getBounds());
|
||||||
|
|
||||||
|
this._map.fitBounds(bounds, this._map.getBoundsOptions());
|
||||||
|
}
|
||||||
|
|
||||||
|
this._map.fire('dataload', {layer: this});
|
||||||
|
}.bind(this));
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* @param map
|
||||||
|
*/
|
||||||
|
onAdd: function (map) {
|
||||||
|
if (this.options.boundsMode === 'fit' && this.options.dynamicLoad) {
|
||||||
|
map.on('moveend', this.refreshData, this);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.refreshData();
|
||||||
|
},
|
||||||
|
pointToLayer: function (feature, latlng) {
|
||||||
|
var type = 'marker';
|
||||||
|
var marker = L.marker(latlng, feature.properties.options);
|
||||||
|
|
||||||
|
if (feature.properties) {
|
||||||
|
if (feature.properties.radius) {
|
||||||
|
marker.setRadius(feature.properties.radius);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (feature.properties.icon) {
|
||||||
|
var icon = this._map.getIcon(feature.properties.icon);
|
||||||
|
|
||||||
|
if (icon) {
|
||||||
|
marker.setIcon(icon);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
L.contao.bindPopupFromFeature(marker, feature);
|
||||||
|
}
|
||||||
|
|
||||||
|
this._map.fire('point:added', {marker: marker, feature: feature, latlng: latlng, type: type});
|
||||||
|
|
||||||
|
return marker;
|
||||||
|
},
|
||||||
|
onEachFeature: function (feature, layer) {
|
||||||
|
if (feature.properties) {
|
||||||
|
L.Util.setOptions(layer, feature.properties.options);
|
||||||
|
|
||||||
|
L.contao.bindPopupFromFeature(layer, feature);
|
||||||
|
|
||||||
|
this._map.fire('feature:added', {feature: feature, layer: layer});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Make an ajax request. Clone of corslite from MapQuest.
|
||||||
|
*/
|
||||||
|
request: function (url, callback, cors) {
|
||||||
|
var sent = false;
|
||||||
|
|
||||||
|
if (typeof window.XMLHttpRequest === 'undefined') {
|
||||||
|
return callback(Error('Browser not supported'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof cors === 'undefined') {
|
||||||
|
var m = url.match(/^\s*https?:\/\/[^\/]*/);
|
||||||
|
cors = m && (m[0] !== location.protocol + '//' + location.hostname +
|
||||||
|
(location.port ? ':' + location.port : ''));
|
||||||
|
}
|
||||||
|
|
||||||
|
var x = new window.XMLHttpRequest();
|
||||||
|
|
||||||
|
function isSuccessful(status) {
|
||||||
|
return status >= 200 && status < 300 || status === 304;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cors && !('withCredentials' in x)) {
|
||||||
|
// IE8-9
|
||||||
|
x = new window.XDomainRequest();
|
||||||
|
|
||||||
|
// Ensure callback is never called synchronously, i.e., before
|
||||||
|
// x.send() returns (this has been observed in the wild).
|
||||||
|
// See https://github.com/mapbox/mapbox.js/issues/472
|
||||||
|
var original = callback;
|
||||||
|
callback = function() {
|
||||||
|
if (sent) {
|
||||||
|
original.apply(this, arguments);
|
||||||
|
} else {
|
||||||
|
var that = this, args = arguments;
|
||||||
|
setTimeout(function() {
|
||||||
|
original.apply(that, args);
|
||||||
|
}, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function loaded() {
|
||||||
|
if (
|
||||||
|
// XDomainRequest
|
||||||
|
x.status === undefined ||
|
||||||
|
// modern browsers
|
||||||
|
isSuccessful(x.status)) callback.call(x, null, x);
|
||||||
|
else callback.call(x, x, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Both `onreadystatechange` and `onload` can fire. `onreadystatechange`
|
||||||
|
// has [been supported for longer](http://stackoverflow.com/a/9181508/229001).
|
||||||
|
if ('onload' in x) {
|
||||||
|
x.onload = loaded;
|
||||||
|
} else {
|
||||||
|
x.onreadystatechange = function readystate() {
|
||||||
|
if (x.readyState === 4) {
|
||||||
|
loaded();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Call the callback with the XMLHttpRequest object as an error and prevent
|
||||||
|
// it from ever being called again by reassigning it to `noop`
|
||||||
|
x.onerror = function error(evt) {
|
||||||
|
// XDomainRequest provides no evt parameter
|
||||||
|
callback.call(this, evt || true, null);
|
||||||
|
callback = function() { };
|
||||||
|
};
|
||||||
|
|
||||||
|
// IE9 must have onprogress be set to a unique function.
|
||||||
|
x.onprogress = function() { };
|
||||||
|
|
||||||
|
x.ontimeout = function(evt) {
|
||||||
|
callback.call(this, evt, null);
|
||||||
|
callback = function() { };
|
||||||
|
};
|
||||||
|
|
||||||
|
x.onabort = function(evt) {
|
||||||
|
callback.call(this, evt, null);
|
||||||
|
callback = function() { };
|
||||||
|
};
|
||||||
|
|
||||||
|
// GET is the only supported HTTP Verb by XDomainRequest and is the
|
||||||
|
// only one supported here.
|
||||||
|
x.open('GET', url, true);
|
||||||
|
|
||||||
|
// Send the request. Sending data is not supported.
|
||||||
|
x.send(null);
|
||||||
|
sent = true;
|
||||||
|
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
});
|
||||||
@@ -280,7 +280,11 @@ $GLOBALS['LEAFLET_LAYERS'] = array
|
|||||||
}
|
}
|
||||||
|
|
||||||
return $label;
|
return $label;
|
||||||
}
|
},
|
||||||
|
'boundsMode' => array(
|
||||||
|
'extend' => true,
|
||||||
|
'fit' => true,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|||||||
@@ -219,13 +219,11 @@ $GLOBALS['TL_DCA']['tl_leaflet_layer'] = array
|
|||||||
'overpassQuery',
|
'overpassQuery',
|
||||||
'overpassEndpoint',
|
'overpassEndpoint',
|
||||||
'minZoom',
|
'minZoom',
|
||||||
'overpassCallback',
|
'boundsMode'
|
||||||
),
|
),
|
||||||
'+expert' => array(
|
'+expert' => array(
|
||||||
'minZoomIndicatorPosition',
|
'onEachFeature',
|
||||||
'debug',
|
'pointToLayer',
|
||||||
'minZoomIndicatorMessage',
|
|
||||||
'minZoomIndicatorMessageNoLayer',
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
190
src/Netzmacht/Contao/Leaflet/Definition/Layer/OverpassLayer.php
Normal file
190
src/Netzmacht/Contao/Leaflet/Definition/Layer/OverpassLayer.php
Normal file
@@ -0,0 +1,190 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package netzmacht
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2016 netzmacht David Molineus. All rights reserved.
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Definition\Layer;
|
||||||
|
|
||||||
|
use Netzmacht\JavascriptBuilder\Encoder;
|
||||||
|
use Netzmacht\JavascriptBuilder\Type\AnonymousFunction;
|
||||||
|
use Netzmacht\JavascriptBuilder\Type\ConvertsToJavascript;
|
||||||
|
use Netzmacht\JavascriptBuilder\Type\Expression;
|
||||||
|
use Netzmacht\LeafletPHP\Definition\AbstractLayer;
|
||||||
|
use Netzmacht\LeafletPHP\Definition\HasOptions;
|
||||||
|
use Netzmacht\LeafletPHP\Encoder\EncodeHelperTrait;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class OverpassLayer provides implementation of https://github.com/kartenkarsten/leaflet-layer-overpass.
|
||||||
|
*
|
||||||
|
* @package Netzmacht\LeafletPHP\Plugins\OverpassLayer
|
||||||
|
*/
|
||||||
|
class OverpassLayer extends AbstractLayer implements HasOptions, ConvertsToJavascript
|
||||||
|
{
|
||||||
|
use EncodeHelperTrait;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public static function getType()
|
||||||
|
{
|
||||||
|
return 'OverpassLayer';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public static function getRequiredLibraries()
|
||||||
|
{
|
||||||
|
$libs = parent::getRequiredLibraries();
|
||||||
|
$libs[] = 'osmtogeojson';
|
||||||
|
|
||||||
|
return $libs;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OverpassLayer constructor.
|
||||||
|
*
|
||||||
|
* @param string $identifier Indicator of the layer.
|
||||||
|
* @param array $options Options.
|
||||||
|
*/
|
||||||
|
public function __construct($identifier, array $options = [])
|
||||||
|
{
|
||||||
|
parent::__construct($identifier);
|
||||||
|
|
||||||
|
$this->setOptions($options);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the debug mode.
|
||||||
|
*
|
||||||
|
* @param bool $debug Debug mode.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setDebug($debug)
|
||||||
|
{
|
||||||
|
return $this->setOption('debug', (bool) $debug);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get debug mode.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function getDebug()
|
||||||
|
{
|
||||||
|
return $this->getOption('debug', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the query.
|
||||||
|
*
|
||||||
|
* @param string $query Query.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setQuery($query)
|
||||||
|
{
|
||||||
|
return $this->setOption('query', $query);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get query.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function getQuery()
|
||||||
|
{
|
||||||
|
return $this->getOption('query', '(node(BBOX)[organic];node(BBOX)[second_hand];);out qt;');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the endpoint.
|
||||||
|
*
|
||||||
|
* @param string $endpoint Endpoint.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setEndpoint($endpoint)
|
||||||
|
{
|
||||||
|
return $this->setOption('endpoint', $endpoint);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get endpoint.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function getEndpoint()
|
||||||
|
{
|
||||||
|
return $this->getOption('endpoint', '//overpass-api.de/api/');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set point to layer function.
|
||||||
|
*
|
||||||
|
* @param Expression|AnonymousFunction $function The function callback.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setPointToLayer($function)
|
||||||
|
{
|
||||||
|
return $this->setOption('pointToLayer', $function);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set on each feature function.
|
||||||
|
*
|
||||||
|
* @param Expression|AnonymousFunction $function The function callback.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setOnEachFeature($function)
|
||||||
|
{
|
||||||
|
return $this->setOption('onEachFeature', $function);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the minZoom.
|
||||||
|
*
|
||||||
|
* @param int $minZoom MinZoom.
|
||||||
|
*
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setMinZoom($minZoom)
|
||||||
|
{
|
||||||
|
return $this->setOption('minZoom', (int) $minZoom);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get minZoom.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function getMinZoom()
|
||||||
|
{
|
||||||
|
return $this->getOption('minZoom', 15);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function encode(Encoder $encoder, $flags = null)
|
||||||
|
{
|
||||||
|
$buffer = sprintf (
|
||||||
|
'%s = new L.OverPassLayer(%s)%s',
|
||||||
|
$encoder->encodeReference($this),
|
||||||
|
$encoder->encodeArray($this->getOptions(), JSON_FORCE_OBJECT),
|
||||||
|
$encoder->close($flags)
|
||||||
|
);
|
||||||
|
|
||||||
|
$buffer .= $this->encodeMethodCalls($this->getMethodCalls(), $encoder, $flags);
|
||||||
|
|
||||||
|
return $buffer;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -10,12 +10,12 @@
|
|||||||
|
|
||||||
namespace Netzmacht\Contao\Leaflet\Mapper\Layer;
|
namespace Netzmacht\Contao\Leaflet\Mapper\Layer;
|
||||||
|
|
||||||
|
use Model;
|
||||||
|
use Netzmacht\Contao\Leaflet\Definition\Layer\OverpassLayer;
|
||||||
use Netzmacht\Contao\Leaflet\Filter\Filter;
|
use Netzmacht\Contao\Leaflet\Filter\Filter;
|
||||||
use Netzmacht\Contao\Leaflet\Mapper\DefinitionMapper;
|
use Netzmacht\Contao\Leaflet\Mapper\DefinitionMapper;
|
||||||
use Netzmacht\Contao\Leaflet\Mapper\OptionsBuilder;
|
|
||||||
use Netzmacht\JavascriptBuilder\Type\Expression;
|
use Netzmacht\JavascriptBuilder\Type\Expression;
|
||||||
use Netzmacht\LeafletPHP\Definition;
|
use Netzmacht\LeafletPHP\Definition;
|
||||||
use Netzmacht\LeafletPHP\Plugins\OverpassLayer\OverpassLayer;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class OverpassLayerMapper
|
* Class OverpassLayerMapper
|
||||||
@@ -36,7 +36,7 @@ class OverpassLayerMapper extends AbstractLayerMapper
|
|||||||
*
|
*
|
||||||
* @var string
|
* @var string
|
||||||
*/
|
*/
|
||||||
protected static $definitionClass = 'Netzmacht\LeafletPHP\Plugins\OverpassLayer\OverpassLayer';
|
protected static $definitionClass = 'Netzmacht\Contao\Leaflet\Definition\Layer\OverpassLayer';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
@@ -47,8 +47,8 @@ class OverpassLayerMapper extends AbstractLayerMapper
|
|||||||
|
|
||||||
$this->optionsBuilder
|
$this->optionsBuilder
|
||||||
->addOption('query', 'overpassQuery')
|
->addOption('query', 'overpassQuery')
|
||||||
->addOption('minzoom', 'minZoom')
|
->addOption('minZoom')
|
||||||
->addOption('debug')
|
->addOption('boundsMode')
|
||||||
->addOption('overpassEndpoint', 'endpoint');
|
->addOption('overpassEndpoint', 'endpoint');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -57,7 +57,7 @@ class OverpassLayerMapper extends AbstractLayerMapper
|
|||||||
*/
|
*/
|
||||||
protected function build(
|
protected function build(
|
||||||
Definition $definition,
|
Definition $definition,
|
||||||
\Model $model,
|
Model $model,
|
||||||
DefinitionMapper $mapper,
|
DefinitionMapper $mapper,
|
||||||
Filter $filter = null,
|
Filter $filter = null,
|
||||||
Definition $parent = null
|
Definition $parent = null
|
||||||
@@ -66,17 +66,12 @@ class OverpassLayerMapper extends AbstractLayerMapper
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$minZoomIndicatorOptions = $definition->getMinZoomIndicatorOptions();
|
if ($model->pointToLayer) {
|
||||||
$minZoomIndicatorOptionsBuilder = new OptionsBuilder();
|
$definition->setPointToLayer(new Expression($model->pointToLayer));
|
||||||
$minZoomIndicatorOptionsBuilder
|
}
|
||||||
->addOption('position', 'minZoomIndicatorPosition')
|
|
||||||
->addOption('minZoomMessageNoLayer', 'minZoomIndicatorMessageNoLayer')
|
|
||||||
->addOption('minZoomMessage', 'minZoomIndicatorMessage');
|
|
||||||
|
|
||||||
$minZoomIndicatorOptionsBuilder->build($minZoomIndicatorOptions, $model);
|
if ($model->onEachFeature) {
|
||||||
|
$definition->setOnEachFeature(new Expression($model->onEachFeature));
|
||||||
if ($model->overpassCallback) {
|
|
||||||
$definition->setCallback(new Expression($model->overpassCallback));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user