mirror of
https://github.com/netzmacht/contao-leaflet-maps.git
synced 2025-11-30 20:13:49 +01:00
Switch to omnivore as default ajax layer.
This commit is contained in:
@@ -24,7 +24,6 @@ L.Contao = L.Class.extend({
|
|||||||
initialize: function() {
|
initialize: function() {
|
||||||
L.Icon.Default.imagePath = 'assets/leaflet/libs/leaflet/images';
|
L.Icon.Default.imagePath = 'assets/leaflet/libs/leaflet/images';
|
||||||
|
|
||||||
this.bindDataLoadingEvents();
|
|
||||||
this.setGeoJsonListeners(L.GeoJSON);
|
this.setGeoJsonListeners(L.GeoJSON);
|
||||||
this.setGeoJsonListeners(L.GeoJSON.AJAX);
|
this.setGeoJsonListeners(L.GeoJSON.AJAX);
|
||||||
},
|
},
|
||||||
@@ -106,6 +105,38 @@ L.Contao = L.Class.extend({
|
|||||||
return this.icons[id];
|
return this.icons[id];
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Layer a url into a layer using omnivore.
|
||||||
|
*
|
||||||
|
* @param url The url being loaded.
|
||||||
|
* @param type The response content format.
|
||||||
|
* @param options Parser options
|
||||||
|
* @param customLayer optional custom layer.
|
||||||
|
* @param map Pass a map object so that the data loading events are passed to the map.
|
||||||
|
*/
|
||||||
|
loadLayer: function(url, type, options, customLayer, map) {
|
||||||
|
if (map) {
|
||||||
|
map.fire('dataloading');
|
||||||
|
}
|
||||||
|
|
||||||
|
var layer = omnivore[type](url, options, customLayer);
|
||||||
|
|
||||||
|
layer.on('ready', function(e) {
|
||||||
|
if (map) {
|
||||||
|
map.fire('dataload');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
layer.on('error', function(e) {
|
||||||
|
if (map) {
|
||||||
|
map.fire('dataload');
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
return layer;
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Point to layer callback. Adds a geo json point to the layer.
|
* Point to layer callback. Adds a geo json point to the layer.
|
||||||
*
|
*
|
||||||
@@ -183,25 +214,6 @@ L.Contao = L.Class.extend({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
|
||||||
* Bind triggered data:loading and data:loaded events to the map.
|
|
||||||
*
|
|
||||||
* These events are fired by leaflet.ajax. The loading indicator listens to the map dataloading and dataloaded
|
|
||||||
* events which is also used by the tile layers.
|
|
||||||
*/
|
|
||||||
bindDataLoadingEvents: function() {
|
|
||||||
L.Map.addInitHook(function () {
|
|
||||||
var map = this;
|
|
||||||
|
|
||||||
this.on('layeradd', function(e) {
|
|
||||||
if (e.layer.on) {
|
|
||||||
e.layer.on('data:loading', function() { map.fire('dataloading'); });
|
|
||||||
e.layer.on('data:loaded', function() { map.fire('dataload'); });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the default geojson listeners to the prototype.
|
* Set the default geojson listeners to the prototype.
|
||||||
*
|
*
|
||||||
@@ -215,7 +227,6 @@ L.Contao = L.Class.extend({
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
window.ContaoLeaflet = new L.Contao();
|
window.ContaoLeaflet = new L.Contao();
|
||||||
|
|||||||
@@ -22,7 +22,6 @@ use Netzmacht\LeafletPHP\Definition\Group\GeoJson;
|
|||||||
use Netzmacht\LeafletPHP\Definition\Group\LayerGroup;
|
use Netzmacht\LeafletPHP\Definition\Group\LayerGroup;
|
||||||
use Netzmacht\LeafletPHP\Definition\Type\LatLngBounds;
|
use Netzmacht\LeafletPHP\Definition\Type\LatLngBounds;
|
||||||
use Netzmacht\LeafletPHP\Definition\UI\Marker;
|
use Netzmacht\LeafletPHP\Definition\UI\Marker;
|
||||||
use Netzmacht\LeafletPHP\Plugins\Ajax\GeoJsonAjax;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class MarkersLayerMapper maps the layer model to the markers definition.
|
* Class MarkersLayerMapper maps the layer model to the markers definition.
|
||||||
@@ -51,12 +50,40 @@ class MarkersLayerMapper extends AbstractLayerMapper implements GeoJsonMapper
|
|||||||
protected function getClassName(\Model $model, DefinitionMapper $mapper, LatLngBounds $bounds = null)
|
protected function getClassName(\Model $model, DefinitionMapper $mapper, LatLngBounds $bounds = null)
|
||||||
{
|
{
|
||||||
if ($model->deferred) {
|
if ($model->deferred) {
|
||||||
return 'Netzmacht\LeafletPHP\Plugins\Ajax\GeoJsonAjax';
|
return 'Netzmacht\LeafletPHP\Plugins\Omnivore\GeoJson';
|
||||||
}
|
}
|
||||||
|
|
||||||
return parent::getClassName($model, $mapper, $bounds);
|
return parent::getClassName($model, $mapper, $bounds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function buildConstructArguments(
|
||||||
|
\Model $model,
|
||||||
|
DefinitionMapper $mapper,
|
||||||
|
LatLngBounds $bounds = null,
|
||||||
|
$elementId = null
|
||||||
|
) {
|
||||||
|
if ($model->deferred) {
|
||||||
|
|
||||||
|
if ($model->pointToLayer) {
|
||||||
|
$layer = new GeoJson($this->getElementId($model, $elementId) . '_1');
|
||||||
|
$layer->setPointToLayer(new Expression($model->pointToLayer));
|
||||||
|
|
||||||
|
return array($this->getElementId($model, $elementId), RequestUrl::create($model->id), array(), $layer);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($options)) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return array($this->getElementId($model, $elementId), RequestUrl::create($model->id));
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::buildConstructArguments($model, $mapper, $bounds, $elementId);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
*/
|
*/
|
||||||
@@ -66,9 +93,7 @@ class MarkersLayerMapper extends AbstractLayerMapper implements GeoJsonMapper
|
|||||||
DefinitionMapper $mapper,
|
DefinitionMapper $mapper,
|
||||||
LatLngBounds $bounds = null
|
LatLngBounds $bounds = null
|
||||||
) {
|
) {
|
||||||
if ($definition instanceof GeoJsonAjax) {
|
if ($definition instanceof LayerGroup) {
|
||||||
$definition->setUrl(RequestUrl::create($model->id));
|
|
||||||
} elseif ($definition instanceof LayerGroup) {
|
|
||||||
$collection = $this->loadMarkerModels($model);
|
$collection = $this->loadMarkerModels($model);
|
||||||
|
|
||||||
if ($collection) {
|
if ($collection) {
|
||||||
|
|||||||
@@ -22,9 +22,9 @@ use Netzmacht\LeafletPHP\Definition\GeoJson\FeatureCollection;
|
|||||||
use Netzmacht\LeafletPHP\Definition\GeoJson\GeoJsonFeature;
|
use Netzmacht\LeafletPHP\Definition\GeoJson\GeoJsonFeature;
|
||||||
use Netzmacht\LeafletPHP\Definition\Group\GeoJson;
|
use Netzmacht\LeafletPHP\Definition\Group\GeoJson;
|
||||||
use Netzmacht\LeafletPHP\Definition\Group\LayerGroup;
|
use Netzmacht\LeafletPHP\Definition\Group\LayerGroup;
|
||||||
|
use Netzmacht\LeafletPHP\Definition\Layer;
|
||||||
use Netzmacht\LeafletPHP\Definition\Type\LatLngBounds;
|
use Netzmacht\LeafletPHP\Definition\Type\LatLngBounds;
|
||||||
use Netzmacht\LeafletPHP\Definition\Vector;
|
use Netzmacht\LeafletPHP\Definition\Vector;
|
||||||
use Netzmacht\LeafletPHP\Plugins\Ajax\GeoJsonAjax;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class VectorsLayerMapper maps the layer model for the Vectors layer definition.
|
* Class VectorsLayerMapper maps the layer model for the Vectors layer definition.
|
||||||
@@ -53,12 +53,45 @@ class VectorsLayerMapper extends AbstractLayerMapper implements GeoJsonMapper
|
|||||||
protected function getClassName(\Model $model, DefinitionMapper $mapper, LatLngBounds $bounds = null)
|
protected function getClassName(\Model $model, DefinitionMapper $mapper, LatLngBounds $bounds = null)
|
||||||
{
|
{
|
||||||
if ($model->deferred) {
|
if ($model->deferred) {
|
||||||
return 'Netzmacht\LeafletPHP\Plugins\Ajax\GeoJsonAjax';
|
return 'Netzmacht\LeafletPHP\Plugins\Omnivore\GeoJson';
|
||||||
}
|
}
|
||||||
|
|
||||||
return parent::getClassName($model, $mapper, $bounds);
|
return parent::getClassName($model, $mapper, $bounds);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function buildConstructArguments(
|
||||||
|
\Model $model,
|
||||||
|
DefinitionMapper $mapper,
|
||||||
|
LatLngBounds $bounds = null,
|
||||||
|
$elementId = null
|
||||||
|
) {
|
||||||
|
if ($model->deferred) {
|
||||||
|
$options = array();
|
||||||
|
|
||||||
|
if ($model->pointToLayer) {
|
||||||
|
$options['pointToLayer'] = new Expression($model->pointToLayer);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($model->onEachFeature) {
|
||||||
|
$options['onEachFeature'] = new Expression($model->onEachFeature);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($options)) {
|
||||||
|
$layer = new GeoJson($this->getElementId($model, $elementId) . '_1');
|
||||||
|
$layer->setOptions($options);
|
||||||
|
|
||||||
|
return array($this->getElementId($model, $elementId), RequestUrl::create($model->id), array(), $layer);
|
||||||
|
}
|
||||||
|
|
||||||
|
return array($this->getElementId($model, $elementId), RequestUrl::create($model->id));
|
||||||
|
}
|
||||||
|
|
||||||
|
return parent::buildConstructArguments($model, $mapper, $bounds, $elementId);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
*/
|
*/
|
||||||
@@ -68,19 +101,21 @@ class VectorsLayerMapper extends AbstractLayerMapper implements GeoJsonMapper
|
|||||||
DefinitionMapper $mapper,
|
DefinitionMapper $mapper,
|
||||||
LatLngBounds $bounds = null
|
LatLngBounds $bounds = null
|
||||||
) {
|
) {
|
||||||
if ($definition instanceof GeoJsonAjax) {
|
if ($definition instanceof LayerGroup) {
|
||||||
$definition->setUrl(RequestUrl::create($model->id));
|
|
||||||
} elseif ($definition instanceof LayerGroup) {
|
|
||||||
$collection = $this->loadVectorModels($model);
|
$collection = $this->loadVectorModels($model);
|
||||||
|
|
||||||
if ($collection) {
|
if ($collection) {
|
||||||
foreach ($collection as $item) {
|
foreach ($collection as $item) {
|
||||||
$definition->addLayer($mapper->handle($item));
|
$vector = $mapper->handle($item);
|
||||||
|
|
||||||
|
if ($vector instanceof Layer) {
|
||||||
|
$definition->addLayer($vector);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($definition instanceof GeoJson || $definition instanceof GeoJsonAjax) {
|
if ($definition instanceof GeoJson) {
|
||||||
if ($model->pointToLayer) {
|
if ($model->pointToLayer) {
|
||||||
$definition->setPointToLayer(new Expression($model->pointToLayer));
|
$definition->setPointToLayer(new Expression($model->pointToLayer));
|
||||||
}
|
}
|
||||||
@@ -104,8 +139,10 @@ class VectorsLayerMapper extends AbstractLayerMapper implements GeoJsonMapper
|
|||||||
$vector = $mapper->handle($item);
|
$vector = $mapper->handle($item);
|
||||||
|
|
||||||
if ($vector instanceof ConvertsToGeoJsonFeature) {
|
if ($vector instanceof ConvertsToGeoJsonFeature) {
|
||||||
$feature->addFeature($vector->toGeoJsonFeature());
|
$vector = $vector->toGeoJsonFeature();
|
||||||
} elseif ($vector instanceof GeoJsonFeature) {
|
}
|
||||||
|
|
||||||
|
if ($vector instanceof GeoJsonFeature) {
|
||||||
$feature->addFeature($vector);
|
$feature->addFeature($vector);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,10 +11,13 @@
|
|||||||
|
|
||||||
namespace Netzmacht\Contao\Leaflet\Subscriber;
|
namespace Netzmacht\Contao\Leaflet\Subscriber;
|
||||||
|
|
||||||
|
use Netzmacht\Javascript\Encoder;
|
||||||
use Netzmacht\Javascript\Event\BuildEvent;
|
use Netzmacht\Javascript\Event\BuildEvent;
|
||||||
use Netzmacht\Javascript\Event\EncodeValueEvent;
|
use Netzmacht\Javascript\Event\EncodeValueEvent;
|
||||||
|
use Netzmacht\LeafletPHP\Definition\Group\GeoJson;
|
||||||
use Netzmacht\LeafletPHP\Definition\Map;
|
use Netzmacht\LeafletPHP\Definition\Map;
|
||||||
use Netzmacht\LeafletPHP\Definition\Type\Icon;
|
use Netzmacht\LeafletPHP\Definition\Type\Icon;
|
||||||
|
use Netzmacht\LeafletPHP\Plugins\Omnivore\OmnivoreLayer;
|
||||||
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +38,8 @@ class EncoderSubscriber implements EventSubscriberInterface
|
|||||||
array('endWrapper', -1000),
|
array('endWrapper', -1000),
|
||||||
),
|
),
|
||||||
EncodeValueEvent::NAME => array(
|
EncodeValueEvent::NAME => array(
|
||||||
array('encodeIcons', 100)
|
array('encodeIcons', 100),
|
||||||
|
array('loadLayer', 100),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -93,4 +97,48 @@ class EncoderSubscriber implements EventSubscriberInterface
|
|||||||
$event->stopPropagation();
|
$event->stopPropagation();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function loadLayer(EncodeValueEvent $event)
|
||||||
|
{
|
||||||
|
$value = $event->getValue();
|
||||||
|
$encoder = $event->getEncoder();
|
||||||
|
|
||||||
|
if ($event->getReferenced() < Encoder::VALUE_REFERENCE_REQUIRED && $value instanceof OmnivoreLayer) {
|
||||||
|
//$event->stopPropagation();
|
||||||
|
$event->addLine(
|
||||||
|
sprintf(
|
||||||
|
'%s = ContaoLeaflet.loadLayer(%s, %s, %s, %s, map.map);',
|
||||||
|
$encoder->encodeReference($value),
|
||||||
|
$encoder->encodeValue($value->getUrl()),
|
||||||
|
$encoder->encodeValue(strtolower(str_replace('Omnivore.', '', $value->getType()))),
|
||||||
|
$encoder->encodeValue($value->getOptions()),
|
||||||
|
$this->encodeCustomLayer($value, $encoder)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encode a custom layer for the omnivore plugin.
|
||||||
|
*
|
||||||
|
* @param OmnivoreLayer $layer The layer.
|
||||||
|
* @param Encoder $encoder The javascript encoder.
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function encodeCustomLayer(OmnivoreLayer $layer, Encoder $encoder)
|
||||||
|
{
|
||||||
|
$customLayer = $layer->getCustomLayer();
|
||||||
|
|
||||||
|
if ($customLayer instanceof GeoJson && !$customLayer->getMethodCalls()) {
|
||||||
|
return sprintf(
|
||||||
|
'L.geoJson(null, %s)',
|
||||||
|
$encoder->encodeValue($customLayer->getOptions())
|
||||||
|
);
|
||||||
|
} elseif ($customLayer) {
|
||||||
|
return $encoder->encodeReference($customLayer);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 'null';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user