2014-12-29 12:17:40 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/**
|
2017-10-05 15:45:43 +02:00
|
|
|
* Leaflet maps for Contao CMS.
|
|
|
|
|
*
|
2016-10-11 10:40:15 +02:00
|
|
|
* @package contao-leaflet-maps
|
2014-12-29 12:17:40 +01:00
|
|
|
* @author David Molineus <david.molineus@netzmacht.de>
|
2017-10-11 15:00:48 +02:00
|
|
|
* @copyright 2014-2017 netzmacht David Molineus. All rights reserved.
|
2017-10-05 15:45:43 +02:00
|
|
|
* @license LGPL-3.0 https://github.com/netzmacht/contao-leaflet-maps/blob/master/LICENSE
|
2014-12-29 12:17:40 +01:00
|
|
|
* @filesource
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace Netzmacht\Contao\Leaflet\Mapper;
|
|
|
|
|
|
2017-10-11 14:27:37 +02:00
|
|
|
use Contao\Model;
|
2014-12-29 12:17:40 +01:00
|
|
|
use Netzmacht\LeafletPHP\Definition;
|
|
|
|
|
|
2015-01-12 19:03:29 +01:00
|
|
|
/**
|
|
|
|
|
* Interface Mapper describes the Mapper which translates a given configuration to the Leaflet definition.
|
|
|
|
|
*
|
|
|
|
|
* @package Netzmacht\Contao\Leaflet\Mapper
|
|
|
|
|
*/
|
2014-12-29 12:17:40 +01:00
|
|
|
interface Mapper
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Map model to the definition.
|
|
|
|
|
*
|
2017-10-11 14:27:37 +02:00
|
|
|
* @param Model|mixed $model The model being built. Usually a contao model, but can be anything.
|
2015-01-09 13:41:09 +01:00
|
|
|
* @param DefinitionMapper $mapper The definition builder.
|
2017-10-11 14:27:37 +02:00
|
|
|
* @param Request $request Optional building request.
|
2015-01-20 16:38:23 +01:00
|
|
|
* @param string $elementId Optional element.
|
|
|
|
|
* @param Definition|null $parent Optional passed parent.
|
2014-12-29 12:17:40 +01:00
|
|
|
*
|
|
|
|
|
* @return Definition
|
|
|
|
|
*/
|
2015-01-20 16:38:23 +01:00
|
|
|
public function handle(
|
|
|
|
|
$model,
|
|
|
|
|
DefinitionMapper $mapper,
|
2017-10-11 14:27:37 +02:00
|
|
|
Request $request = null,
|
2015-01-20 16:38:23 +01:00
|
|
|
$elementId = null,
|
|
|
|
|
Definition $parent = null
|
|
|
|
|
);
|
2014-12-29 12:17:40 +01:00
|
|
|
|
|
|
|
|
/**
|
2015-01-06 14:55:53 +01:00
|
|
|
* Check if mapper is responsible for the model.
|
2014-12-29 12:17:40 +01:00
|
|
|
*
|
2017-10-11 14:27:37 +02:00
|
|
|
* @param Model $model The model being build.
|
|
|
|
|
* @param Request $request Optional building request.
|
2014-12-29 12:17:40 +01:00
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2017-10-11 14:27:37 +02:00
|
|
|
public function match($model, Request $request = null);
|
2014-12-29 12:17:40 +01:00
|
|
|
}
|