Ongoing development.
@@ -1,6 +1,6 @@
|
|||||||
|
|
||||||
.tl_listing_container.tree_view ul > li.tl_file {
|
.tl_listing_container.tree_view ul > li.tl_file {
|
||||||
background: url('./../img/folPlus.gif') no-repeat 6px 1px;
|
background: url('./../img/fol-placeholder.gif') no-repeat 6px 1px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.tl_listing_container.tree_view > ul > li.tl_file {
|
.tl_listing_container.tree_view > ul > li.tl_file {
|
||||||
|
|||||||
BIN
module/assets/img/control.png
Normal file
|
After Width: | Height: | Size: 778 B |
BIN
module/assets/img/fol-placeholder.gif
Normal file
|
After Width: | Height: | Size: 208 B |
|
Before Width: | Height: | Size: 222 B |
BIN
module/assets/img/geolocation_sight.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
module/assets/img/geotag.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
module/assets/img/sitemap_image.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
module/assets/img/table_heatmap.png
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
module/assets/img/tile.png
Normal file
|
After Width: | Height: | Size: 686 B |
@@ -4,7 +4,7 @@
|
|||||||
* Backend module.
|
* Backend module.
|
||||||
*/
|
*/
|
||||||
$GLOBALS['BE_MOD']['content']['leaflet'] = array(
|
$GLOBALS['BE_MOD']['content']['leaflet'] = array(
|
||||||
'tables' => array('tl_leaflet_map', 'tl_leaflet_layer'),
|
'tables' => array('tl_leaflet_map', 'tl_leaflet_layer', 'tl_leaflet_control'),
|
||||||
'icon' => 'system/modules/leaflet/assets/img/leaflet.png',
|
'icon' => 'system/modules/leaflet/assets/img/leaflet.png',
|
||||||
'stylesheet' => 'system/modules/leaflet/assets/css/backend.css',
|
'stylesheet' => 'system/modules/leaflet/assets/css/backend.css',
|
||||||
);
|
);
|
||||||
@@ -20,6 +20,7 @@ $GLOBALS['TL_CTE']['includes']['leaflet'] = 'Netzmacht\Contao\Leaflet\LeafletMap
|
|||||||
*/
|
*/
|
||||||
$GLOBALS['TL_MODELS']['tl_leaflet_map'] = 'Netzmacht\Contao\Leaflet\Model\MapModel';
|
$GLOBALS['TL_MODELS']['tl_leaflet_map'] = 'Netzmacht\Contao\Leaflet\Model\MapModel';
|
||||||
$GLOBALS['TL_MODELS']['tl_leaflet_layer'] = 'Netzmacht\Contao\Leaflet\Model\LayerModel';
|
$GLOBALS['TL_MODELS']['tl_leaflet_layer'] = 'Netzmacht\Contao\Leaflet\Model\LayerModel';
|
||||||
|
$GLOBALS['TL_MODELS']['tl_leaflet_control'] = 'Netzmacht\Contao\Leaflet\Model\ControlModel';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -30,6 +31,10 @@ $GLOBALS['TL_MODELS']['tl_leaflet_layer'] = 'Netzmacht\Contao\Leaflet\Model\Laye
|
|||||||
$GLOBALS['LEAFLET_MAPPERS'] = array();
|
$GLOBALS['LEAFLET_MAPPERS'] = array();
|
||||||
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\MapMapper';
|
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\MapMapper';
|
||||||
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\Layer\ProviderLayerMapper';
|
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\Layer\ProviderLayerMapper';
|
||||||
|
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\Control\ZoomControlMapper';
|
||||||
|
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\Control\ScaleControlMapper';
|
||||||
|
$GLOBALS['LEAFLET_MAPPERS'][] = 'Netzmacht\Contao\Leaflet\Mapper\Control\LayersControlMapper';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Leaflet encoders.
|
* Leaflet encoders.
|
||||||
@@ -50,12 +55,34 @@ $GLOBALS['LEAFLET_ENCODERS'][] = 'Netzmacht\LeafletPHP\Encoder\RasterEncoder';
|
|||||||
$GLOBALS['LEAFLET_ENCODERS'][] = 'Netzmacht\LeafletPHP\Encoder\VectorEncoder';
|
$GLOBALS['LEAFLET_ENCODERS'][] = 'Netzmacht\LeafletPHP\Encoder\VectorEncoder';
|
||||||
$GLOBALS['LEAFLET_ENCODERS'][] = 'Netzmacht\Contao\Leaflet\Subscriber\EncoderSubscriber';
|
$GLOBALS['LEAFLET_ENCODERS'][] = 'Netzmacht\Contao\Leaflet\Subscriber\EncoderSubscriber';
|
||||||
|
|
||||||
$GLOBALS['LEAFLET_LAYERS'][] = 'provider';
|
|
||||||
|
/*
|
||||||
|
* Leaflet layer types.
|
||||||
|
*
|
||||||
|
* The type is used for the database driven definitions.
|
||||||
|
*/
|
||||||
|
$GLOBALS['LEAFLET_LAYERS'] = array();
|
||||||
|
$GLOBALS['LEAFLET_LAYERS']['default'] = array('children' => true);
|
||||||
|
$GLOBALS['LEAFLET_LAYERS']['provider'] = array('children' => false);
|
||||||
|
$GLOBALS['LEAFLET_LAYERS']['group'] = array('children' => true, 'geojson' => true);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* leaflet controls.
|
||||||
|
*
|
||||||
|
* Supported leaflet control types. Register your type for the database driven definition here.
|
||||||
|
*/
|
||||||
|
$GLOBALS['LEAFLET_CONTROLS'] = array();
|
||||||
|
$GLOBALS['LEAFLET_CONTROLS'][] = 'zoom';
|
||||||
|
$GLOBALS['LEAFLET_CONTROLS'][] = 'layers';
|
||||||
|
$GLOBALS['LEAFLET_CONTROLS'][] = 'scale';
|
||||||
|
$GLOBALS['LEAFLET_CONTROLS'][] = 'attribution';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Leaflet tile layer providers.
|
* Leaflet tile layer providers.
|
||||||
*/
|
*/
|
||||||
require_once __DIR__ . '/leaflet_providers.php';
|
require_once TL_ROOT . '/system/modules/leaflet/config/leaflet_providers.php';
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Leaflet assets.
|
* Leaflet assets.
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'config' => array(
|
'config' => array(
|
||||||
'dataContainer' => 'Table',
|
'dataContainer' => 'Table',
|
||||||
'enableVersioning' => true,
|
'enableVersioning' => true,
|
||||||
|
'ptable' => 'tl_leaflet_map',
|
||||||
'sql' => array
|
'sql' => array
|
||||||
(
|
(
|
||||||
'keys' => array
|
'keys' => array
|
||||||
@@ -19,14 +20,16 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
(
|
(
|
||||||
'sorting' => array
|
'sorting' => array
|
||||||
(
|
(
|
||||||
'mode' => 1,
|
'mode' => 4,
|
||||||
'fields' => array('title'),
|
'fields' => array('sorting'),
|
||||||
'flag' => 1
|
'headerFields' => array('title'),
|
||||||
|
'flag' => 1,
|
||||||
|
'child_record_callback' => array('Netzmacht\Contao\Leaflet\Dca\Control', 'generateRow'),
|
||||||
),
|
),
|
||||||
'label' => array
|
'label' => array
|
||||||
(
|
(
|
||||||
'fields' => array('title'),
|
'fields' => array('title'),
|
||||||
'format' => '%s'
|
'format' => '%s',
|
||||||
),
|
),
|
||||||
'global_operations' => array
|
'global_operations' => array
|
||||||
(
|
(
|
||||||
@@ -68,18 +71,24 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
||||||
|
'palettes' => array(
|
||||||
|
'__selector__' => array('type')
|
||||||
|
),
|
||||||
|
|
||||||
'metapalettes' => array(
|
'metapalettes' => array(
|
||||||
'default' => array(
|
'default' => array(
|
||||||
'name' => array('title', 'type', 'position'),
|
'name' => array('title', 'alias', 'type', 'position'),
|
||||||
|
'config' => array(),
|
||||||
|
'active' => array('active')
|
||||||
),
|
),
|
||||||
'zoom extends default' => array(
|
'zoom extends default' => array(
|
||||||
'zoom' => array('zoomInText', 'zoomOutText', 'zoomInTitle', 'zoomOutTitle'),
|
'config' => array('zoomInText', 'zoomOutText', 'zoomInTitle', 'zoomOutTitle'),
|
||||||
),
|
),
|
||||||
'layers extends default' => array(
|
'layers extends default' => array(
|
||||||
'layers' => array('collapsed', 'autoZIndex')
|
'config' => array('layers', 'collapsed', 'autoZIndex')
|
||||||
),
|
),
|
||||||
'scale extends default' => array(
|
'scale extends default' => array(
|
||||||
'scale' => array('maxWidth', 'scale', 'updateWhenIdle')
|
'config' => array('maxWidth', 'metric', 'imperial', 'updateWhenIdle')
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
|
|
||||||
@@ -89,33 +98,72 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
(
|
(
|
||||||
'sql' => "int(10) unsigned NOT NULL auto_increment"
|
'sql' => "int(10) unsigned NOT NULL auto_increment"
|
||||||
),
|
),
|
||||||
|
'pid' => array
|
||||||
|
(
|
||||||
|
'sql' => "int(10) unsigned NOT NULL default '0'"
|
||||||
|
),
|
||||||
'tstamp' => array
|
'tstamp' => array
|
||||||
(
|
(
|
||||||
'sql' => "int(10) unsigned NOT NULL default '0'"
|
'sql' => "int(10) unsigned NOT NULL default '0'"
|
||||||
),
|
),
|
||||||
|
'sorting' => array
|
||||||
|
(
|
||||||
|
'sql' => "int(10) unsigned NOT NULL default '0'"
|
||||||
|
),
|
||||||
'title' => array
|
'title' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['title'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['title'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => true, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
|
'alias' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['alias'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'text',
|
||||||
|
'eval' => array('mandatory' => false, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
|
),
|
||||||
|
'type' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['type'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'select',
|
||||||
|
'eval' => array(
|
||||||
|
'mandatory' => true,
|
||||||
|
'tl_class' => 'w50',
|
||||||
|
'includeBlankOption' => true,
|
||||||
|
'submitOnChange' => true,
|
||||||
|
'chosen' => true,
|
||||||
|
),
|
||||||
|
'options' => $GLOBALS['LEAFLET_CONTROLS'],
|
||||||
|
'sql' => "varchar(32) NOT NULL default ''"
|
||||||
|
),
|
||||||
'position' => array
|
'position' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['position'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['position'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'select',
|
'inputType' => 'select',
|
||||||
'options' => array('topleft', 'topright', 'bottomleft', 'bottomright'),
|
'options' => array('topleft', 'topright', 'bottomleft', 'bottomright'),
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => true, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
|
'active' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['active'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'checkbox',
|
||||||
|
'eval' => array('tl_class' => 'w50'),
|
||||||
|
'sql' => "char(1) NOT NULL default ''"
|
||||||
|
),
|
||||||
'zoomInText' => array
|
'zoomInText' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => false, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'zoomOutText' => array
|
'zoomOutText' => array
|
||||||
@@ -123,7 +171,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => false, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'zoomInTitle' => array
|
'zoomInTitle' => array
|
||||||
@@ -131,7 +179,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => false, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'zoomOutTitle' => array
|
'zoomOutTitle' => array
|
||||||
@@ -139,7 +187,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['zoomInText'],
|
||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => array('mandatory' => true, 'maxlength' => 255),
|
'eval' => array('mandatory' => false, 'maxlength' => 255, 'tl_class' => 'w50'),
|
||||||
'sql' => "varchar(255) NOT NULL default ''"
|
'sql' => "varchar(255) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'collapsed' => array
|
'collapsed' => array
|
||||||
@@ -148,7 +196,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'checkbox',
|
'inputType' => 'checkbox',
|
||||||
'default' => '1',
|
'default' => '1',
|
||||||
'eval' => array(),
|
'eval' => array('tl_class' => 'w50'),
|
||||||
'sql' => "char(1) NOT NULL default ''"
|
'sql' => "char(1) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'autoZIndex' => array
|
'autoZIndex' => array
|
||||||
@@ -157,7 +205,78 @@ $GLOBALS['TL_DCA']['tl_leaflet_control'] = array
|
|||||||
'exclude' => true,
|
'exclude' => true,
|
||||||
'inputType' => 'checkbox',
|
'inputType' => 'checkbox',
|
||||||
'default' => '1',
|
'default' => '1',
|
||||||
'eval' => array(),
|
'eval' => array('tl_class' => 'w50'),
|
||||||
|
'sql' => "char(1) NOT NULL default ''"
|
||||||
|
),
|
||||||
|
'layers' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['layers'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'multiColumnWizard',
|
||||||
|
'eval' => array
|
||||||
|
(
|
||||||
|
'tl_class' => 'clr',
|
||||||
|
'columnFields' => array
|
||||||
|
(
|
||||||
|
'layer' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['layer'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'select',
|
||||||
|
'options_callback' => array('Netzmacht\Contao\Leaflet\Dca\Control', 'getLayers'),
|
||||||
|
'eval' => array(
|
||||||
|
'style' => 'width: 200px',
|
||||||
|
'chosen' => true,
|
||||||
|
'includeBlankOption' => true
|
||||||
|
),
|
||||||
|
),
|
||||||
|
'mode' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['layer'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'select',
|
||||||
|
'options' => array('base', 'overlay'),
|
||||||
|
'eval' => array(
|
||||||
|
'style' => 'width: 200px'
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
),
|
||||||
|
'sql' => "mediumblob NULL"
|
||||||
|
),
|
||||||
|
'maxWidth' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['maxWidth'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'text',
|
||||||
|
'default' => 100,
|
||||||
|
'eval' => array('tl_class' => 'w50', 'rgxp' => 'digit'),
|
||||||
|
'sql' => "int(5) NOT NULL default '100'"
|
||||||
|
),
|
||||||
|
'metric' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['metric'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'checkbox',
|
||||||
|
'default' => '1',
|
||||||
|
'eval' => array('tl_class' => 'w50 clr'),
|
||||||
|
'sql' => "char(1) NOT NULL default '1'"
|
||||||
|
),
|
||||||
|
'imperial' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['imperial'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'checkbox',
|
||||||
|
'default' => '1',
|
||||||
|
'eval' => array('tl_class' => 'w50'),
|
||||||
|
'sql' => "char(1) NOT NULL default '1'"
|
||||||
|
),
|
||||||
|
'updateWhenIdle' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_control']['updateWhenIdle'],
|
||||||
|
'exclude' => true,
|
||||||
|
'inputType' => 'checkbox',
|
||||||
|
'eval' => array('tl_class' => 'w50'),
|
||||||
'sql' => "char(1) NOT NULL default ''"
|
'sql' => "char(1) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
|||||||
@@ -20,7 +20,8 @@ $GLOBALS['TL_DCA']['tl_leaflet_layer'] = array
|
|||||||
'mode' => 5,
|
'mode' => 5,
|
||||||
'fields' => array('title'),
|
'fields' => array('title'),
|
||||||
'flag' => 1,
|
'flag' => 1,
|
||||||
'icon' => 'system/modules/leaflet/assets/img/layers.png'
|
'icon' => 'system/modules/leaflet/assets/img/layers.png',
|
||||||
|
'paste_button_callback' => array('Netzmacht\Contao\Leaflet\Dca\Layer', 'getPasteButtons'),
|
||||||
),
|
),
|
||||||
'label' => array
|
'label' => array
|
||||||
(
|
(
|
||||||
@@ -29,6 +30,13 @@ $GLOBALS['TL_DCA']['tl_leaflet_layer'] = array
|
|||||||
),
|
),
|
||||||
'global_operations' => array
|
'global_operations' => array
|
||||||
(
|
(
|
||||||
|
'map' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_layer']['map'],
|
||||||
|
'href' => 'table=tl_leaflet_map',
|
||||||
|
'icon' => 'system/modules/leaflet/assets/img/leaflet.png',
|
||||||
|
'attributes' => 'onclick="Backend.getScrollOffset();" accesskey="m"'
|
||||||
|
),
|
||||||
'all' => array
|
'all' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['MSC']['all'],
|
'label' => &$GLOBALS['TL_LANG']['MSC']['all'],
|
||||||
@@ -51,6 +59,13 @@ $GLOBALS['TL_DCA']['tl_leaflet_layer'] = array
|
|||||||
'href' => 'act=copy',
|
'href' => 'act=copy',
|
||||||
'icon' => 'copy.gif'
|
'icon' => 'copy.gif'
|
||||||
),
|
),
|
||||||
|
'cut' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_layer']['cut'],
|
||||||
|
'href' => 'act=paste&mode=cut',
|
||||||
|
'icon' => 'cut.gif',
|
||||||
|
'attributes' => 'onclick="Backend.getScrollOffset()"',
|
||||||
|
),
|
||||||
'delete' => array
|
'delete' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_layer']['delete'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_layer']['delete'],
|
||||||
@@ -129,7 +144,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_layer'] = array
|
|||||||
'submitOnChange' => true,
|
'submitOnChange' => true,
|
||||||
'chosen' => true,
|
'chosen' => true,
|
||||||
),
|
),
|
||||||
'options' => &$GLOBALS['LEAFLET_LAYERS'],
|
'options' => array_keys($GLOBALS['LEAFLET_LAYERS']),
|
||||||
'sql' => "varchar(32) NOT NULL default ''"
|
'sql' => "varchar(32) NOT NULL default ''"
|
||||||
),
|
),
|
||||||
'tile_provider' => array(
|
'tile_provider' => array(
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ $GLOBALS['TL_DCA']['tl_leaflet_map'] = array
|
|||||||
'config' => array(
|
'config' => array(
|
||||||
'dataContainer' => 'Table',
|
'dataContainer' => 'Table',
|
||||||
'enableVersioning' => true,
|
'enableVersioning' => true,
|
||||||
|
'ctable' => array('tl_leaflet_control'),
|
||||||
'sql' => array
|
'sql' => array
|
||||||
(
|
(
|
||||||
'keys' => array
|
'keys' => array
|
||||||
@@ -52,6 +53,13 @@ $GLOBALS['TL_DCA']['tl_leaflet_map'] = array
|
|||||||
'href' => 'act=edit',
|
'href' => 'act=edit',
|
||||||
'icon' => 'header.gif'
|
'icon' => 'header.gif'
|
||||||
),
|
),
|
||||||
|
'controls' => array
|
||||||
|
(
|
||||||
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_map']['controls'],
|
||||||
|
'href' => 'table=tl_leaflet_control',
|
||||||
|
'icon' => 'system/modules/leaflet/assets/img/control.png',
|
||||||
|
'attributes' => 'onclick="Backend.getScrollOffset();" accesskey="e"'
|
||||||
|
),
|
||||||
'copy' => array
|
'copy' => array
|
||||||
(
|
(
|
||||||
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_map']['copy'],
|
'label' => &$GLOBALS['TL_LANG']['tl_leaflet_map']['copy'],
|
||||||
|
|||||||
25
src/Netzmacht/Contao/Leaflet/Dca/Control.php
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Dca;
|
||||||
|
|
||||||
|
|
||||||
|
class Control
|
||||||
|
{
|
||||||
|
public function generateRow($row)
|
||||||
|
{
|
||||||
|
return sprintf(
|
||||||
|
'%s <span class="tl_gray">[%s]</span>',
|
||||||
|
$row['title'],
|
||||||
|
$row['type']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -14,6 +14,12 @@ namespace Netzmacht\Contao\Leaflet\Dca;
|
|||||||
|
|
||||||
class Layer
|
class Layer
|
||||||
{
|
{
|
||||||
|
private $layers;
|
||||||
|
|
||||||
|
public function __construct()
|
||||||
|
{
|
||||||
|
$this->layers = &$GLOBALS['LEAFLET_LAYERS'];
|
||||||
|
}
|
||||||
public function getVariants($dataContainer)
|
public function getVariants($dataContainer)
|
||||||
{
|
{
|
||||||
if ($dataContainer->activeRecord
|
if ($dataContainer->activeRecord
|
||||||
@@ -25,4 +31,49 @@ class Layer
|
|||||||
|
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Call paste_button_callback (&$dc, $row, $table, $cr, $childs, $previous, $next)
|
||||||
|
public function getPasteButtons($dataContainer, $row, $table, $whatever, $children)
|
||||||
|
{
|
||||||
|
$pasteAfterUrl = \Controller::addToUrl(
|
||||||
|
'act='.$children['mode'].'&mode=1&pid='.$row['id']
|
||||||
|
.(!is_array($children['id']) ? '&id='.$children['id'] : '')
|
||||||
|
);
|
||||||
|
|
||||||
|
$buffer = sprintf(
|
||||||
|
'<a href="%s" title="%s" onclick="Backend.getScrollOffset()">%s</a> ',
|
||||||
|
$pasteAfterUrl,
|
||||||
|
specialchars(sprintf($GLOBALS['TL_LANG'][$table]['pasteafter'][1], $row['id'])),
|
||||||
|
\Image::getHtml(
|
||||||
|
'pasteafter.gif',
|
||||||
|
sprintf($GLOBALS['TL_LANG'][$table]['pasteafter'][1], $row['id'])
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!empty($this->layers[$row['type']]['children'])) {
|
||||||
|
$pasteIntoUrl = \Controller::addToUrl(
|
||||||
|
sprintf(
|
||||||
|
'act=%s&mode=2&pid=%s%s',
|
||||||
|
$children['mode'],
|
||||||
|
$row['id'],
|
||||||
|
!is_array($children['id']) ? '&id='.$children['id'] : ''
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$buffer .= sprintf(
|
||||||
|
'<a href="%s" title="%s" onclick="Backend.getScrollOffset()">%s</a> ',
|
||||||
|
$pasteIntoUrl,
|
||||||
|
specialchars(sprintf($GLOBALS['TL_LANG'][$table]['pasteinto'][1], $row['id'])),
|
||||||
|
\Image::getHtml(
|
||||||
|
'pasteinto.gif',
|
||||||
|
sprintf($GLOBALS['TL_LANG'][$table]['pasteinto'][1], $row['id'])
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
} elseif ($row['id'] > 0) {
|
||||||
|
$buffer .= \Image::getHtml('pasteinto_.gif');
|
||||||
|
}
|
||||||
|
|
||||||
|
return $buffer;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -20,6 +20,9 @@ use Netzmacht\LeafletPHP\Definition;
|
|||||||
*/
|
*/
|
||||||
abstract class AbstractMapper implements Mapper
|
abstract class AbstractMapper implements Mapper
|
||||||
{
|
{
|
||||||
|
const VALUE_NOT_EMPTY = '__value_not_empty__';
|
||||||
|
const VALUE_EMPTY = '__value_empty__';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class of the model being build.
|
* Class of the model being build.
|
||||||
*
|
*
|
||||||
@@ -109,8 +112,10 @@ abstract class AbstractMapper implements Mapper
|
|||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
public function addConditionalOption($column, $option, $mapping = null, $value = '1')
|
public function addConditionalOption($column, $option = null, $mapping = null, $value = self::VALUE_NOT_EMPTY)
|
||||||
{
|
{
|
||||||
|
$option = $option ?: $column;
|
||||||
|
|
||||||
if (!isset($this->conditional[$column][$value][$option])) {
|
if (!isset($this->conditional[$column][$value][$option])) {
|
||||||
$this->conditional[$column][$value][$option] = $this->getMapping($option, $mapping);
|
$this->conditional[$column][$value][$option] = $this->getMapping($option, $mapping);
|
||||||
}
|
}
|
||||||
@@ -127,7 +132,7 @@ abstract class AbstractMapper implements Mapper
|
|||||||
*
|
*
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
public function addConditionalOptions($column, array $options, $value = '1')
|
public function addConditionalOptions($column, array $options, $value = self::VALUE_NOT_EMPTY)
|
||||||
{
|
{
|
||||||
foreach ($options as $key => $option) {
|
foreach ($options as $key => $option) {
|
||||||
if (is_numeric($key)) {
|
if (is_numeric($key)) {
|
||||||
@@ -214,7 +219,7 @@ abstract class AbstractMapper implements Mapper
|
|||||||
protected function buildConstructArguments(\Model $model, DefinitionMapper $mapper)
|
protected function buildConstructArguments(\Model $model, DefinitionMapper $mapper)
|
||||||
{
|
{
|
||||||
return array(
|
return array(
|
||||||
$model->alias ?: $model->id
|
$model->alias ?: (str_replace('tl_leaflet_', '', $model->getTable()) . '_' . $model->id)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -243,7 +248,11 @@ abstract class AbstractMapper implements Mapper
|
|||||||
{
|
{
|
||||||
foreach ($this->conditional as $column => $conditions) {
|
foreach ($this->conditional as $column => $conditions) {
|
||||||
foreach ($conditions as $value => $options) {
|
foreach ($conditions as $value => $options) {
|
||||||
if ($model->$column == $value) {
|
if ($value === static::VALUE_EMPTY && empty($model->$column)) {
|
||||||
|
$this->applyOptions($options, $definition, $model);
|
||||||
|
} elseif ($value === static::VALUE_NOT_EMPTY && !empty($model->$column)) {
|
||||||
|
$this->applyOptions($options, $definition, $model);
|
||||||
|
} elseif ($model->$column == $value) {
|
||||||
$this->applyOptions($options, $definition, $model);
|
$this->applyOptions($options, $definition, $model);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,7 +12,7 @@
|
|||||||
namespace Netzmacht\Contao\Leaflet\Mapper;
|
namespace Netzmacht\Contao\Leaflet\Mapper;
|
||||||
|
|
||||||
|
|
||||||
abstract class AbstractLayerMapper extends AbstractMapper
|
abstract class AbstractTypeMapper extends AbstractMapper
|
||||||
{
|
{
|
||||||
protected static $type;
|
protected static $type;
|
||||||
|
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Mapper\Control;
|
||||||
|
|
||||||
|
use Netzmacht\Contao\Leaflet\Mapper\AbstractTypeMapper;
|
||||||
|
|
||||||
|
class AbstractControlMapper extends AbstractTypeMapper
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Class of the model being build.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $modelClass = 'Netzmacht\Contao\Leaflet\Model\ControlModel';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function initialize()
|
||||||
|
{
|
||||||
|
$this->addOption('position');
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,30 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Mapper\Control;
|
||||||
|
|
||||||
|
|
||||||
|
class LayersControlMapper extends AbstractControlMapper
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Class of the definition being created.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $definitionClass = 'Netzmacht\LeafletPHP\Definition\Control\Layers';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Layer type.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $type = 'layers';
|
||||||
|
}
|
||||||
@@ -0,0 +1,44 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Mapper\Control;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ScaleControlMapper maps the database item of the type "scale" to the scale control.
|
||||||
|
*
|
||||||
|
* @package Netzmacht\Contao\Leaflet\Mapper\Control
|
||||||
|
*/
|
||||||
|
class ScaleControlMapper extends AbstractControlMapper
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Class of the definition being created.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $definitionClass = 'Netzmacht\LeafletPHP\Definition\Control\Scale';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Layer type.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $type = 'scale';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function initialize()
|
||||||
|
{
|
||||||
|
parent::initialize();
|
||||||
|
|
||||||
|
$this->addOptions('maxWidth', 'metric', 'imperial', 'updateWhenIdle');
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,48 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Mapper\Control;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class ZoomControlMapper maps the zoom database definition to the zoom control.
|
||||||
|
*
|
||||||
|
* @package Netzmacht\Contao\Leaflet\Mapper\Control
|
||||||
|
*/
|
||||||
|
class ZoomControlMapper extends AbstractControlMapper
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Class of the definition being created.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $definitionClass = 'Netzmacht\LeafletPHP\Definition\Control\Zoom';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Layer type.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected static $type = 'zoom';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
protected function initialize()
|
||||||
|
{
|
||||||
|
parent::initialize();
|
||||||
|
|
||||||
|
$this
|
||||||
|
->addConditionalOption('zoomInText')
|
||||||
|
->addConditionalOption('zoomOutText')
|
||||||
|
->addConditionalOption('zoomInTitle')
|
||||||
|
->addConditionalOption('zoomOutTitle');
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -12,11 +12,11 @@
|
|||||||
namespace Netzmacht\Contao\Leaflet\Mapper\Layer;
|
namespace Netzmacht\Contao\Leaflet\Mapper\Layer;
|
||||||
|
|
||||||
|
|
||||||
use Netzmacht\Contao\Leaflet\Mapper\AbstractLayerMapper;
|
use Netzmacht\Contao\Leaflet\Mapper\AbstractTypeMapper;
|
||||||
use Netzmacht\Contao\Leaflet\Mapper\DefinitionMapper;
|
use Netzmacht\Contao\Leaflet\Mapper\DefinitionMapper;
|
||||||
use Netzmacht\LeafletPHP\Definition;
|
use Netzmacht\LeafletPHP\Definition;
|
||||||
|
|
||||||
class ProviderLayerMapper extends AbstractLayerMapper
|
class ProviderLayerMapper extends AbstractTypeMapper
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Class of the model being build.
|
* Class of the model being build.
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
|
|
||||||
namespace Netzmacht\Contao\Leaflet\Mapper;
|
namespace Netzmacht\Contao\Leaflet\Mapper;
|
||||||
|
|
||||||
|
use Netzmacht\Contao\Leaflet\Model\ControlModel;
|
||||||
use Netzmacht\Contao\Leaflet\Model\LayerModel;
|
use Netzmacht\Contao\Leaflet\Model\LayerModel;
|
||||||
use Netzmacht\Contao\Leaflet\Model\MapModel;
|
use Netzmacht\Contao\Leaflet\Model\MapModel;
|
||||||
use Netzmacht\LeafletPHP\Definition;
|
use Netzmacht\LeafletPHP\Definition;
|
||||||
@@ -93,6 +94,18 @@ class MapMapper extends AbstractMapper
|
|||||||
*/
|
*/
|
||||||
private function buildControls(Map $map, MapModel$model, DefinitionMapper $mapper)
|
private function buildControls(Map $map, MapModel$model, DefinitionMapper $mapper)
|
||||||
{
|
{
|
||||||
|
$collection = ControlModel::findBy(
|
||||||
|
array('pid=?', 'active=1'),
|
||||||
|
array($model->id),
|
||||||
|
array('order' => 'sorting')
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($collection) {
|
||||||
|
foreach ($collection as $control) {
|
||||||
|
$control = $mapper->handle($control);
|
||||||
|
$map->addControl($control);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
17
src/Netzmacht/Contao/Leaflet/Model/ControlModel.php
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package dev
|
||||||
|
* @author David Molineus <david.molineus@netzmacht.de>
|
||||||
|
* @copyright 2015 netzmacht creative David Molineus
|
||||||
|
* @license LGPL 3.0
|
||||||
|
* @filesource
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Netzmacht\Contao\Leaflet\Model;
|
||||||
|
|
||||||
|
class ControlModel extends \Model
|
||||||
|
{
|
||||||
|
protected static $strTable = 'tl_leaflet_control';
|
||||||
|
}
|
||||||
@@ -47,8 +47,9 @@ class EncoderSubscriber implements EventSubscriberInterface
|
|||||||
|
|
||||||
if ($object instanceof Map) {
|
if ($object instanceof Map) {
|
||||||
$attribution = <<<HTML
|
$attribution = <<<HTML
|
||||||
map.map.attributionControl.addAttribution(
|
map.map.attributionControl.setPrefix(
|
||||||
'<a href="http://www.netzmacht.de/contao-leaflet">netzmacht <em>creative</em></a>'
|
'<a href="http://www.leafletjs.com" title="A JS library for interactive maps">Leaflet</a> | ' +
|
||||||
|
'<a href="http://www.netzmacht.de/contao-leaflet" title="Leaflet extension for Contao CMS">netzmacht <em>creative</em></a>'
|
||||||
);
|
);
|
||||||
HTML;
|
HTML;
|
||||||
$event->getOutput()->addLine($attribution);
|
$event->getOutput()->addLine($attribution);
|
||||||
|
|||||||