X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=openstreetmap%2Fopenstreetmap.php;h=1a4a55714f8fe4b76f08b37d4d530f9ffdd480c7;hb=83425a7f269e57cf9d3959da59bfd4191e86ee91;hp=175e5862a0ae813c6aefade1f913723cbcaba772;hpb=48dcbc6f3fc3edae74e3ea2c823011bfb7c26081;p=friendica-addons.git diff --git a/openstreetmap/openstreetmap.php b/openstreetmap/openstreetmap.php index 175e5862..1a4a5571 100644 --- a/openstreetmap/openstreetmap.php +++ b/openstreetmap/openstreetmap.php @@ -8,31 +8,34 @@ * Author: Klaus Weidenbach * */ - -require_once('include/cache.php'); - +use Friendica\Core\Addon; +use Friendica\Core\Cache; use Friendica\Core\Config; +use Friendica\Core\L10n; +use Friendica\Util\Network; - -function openstreetmap_install() { - register_hook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); - register_hook('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); - register_hook('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); - register_hook('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); +function openstreetmap_install() +{ + Addon::registerHook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); + Addon::registerHook('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); + Addon::registerHook('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); + Addon::registerHook('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); logger("installed openstreetmap"); } -function openstreetmap_uninstall() { - unregister_hook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); - unregister_hook('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); - unregister_hook('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); - unregister_hook('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); +function openstreetmap_uninstall() +{ + Addon::unregisterHook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); + Addon::unregisterHook('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); + Addon::unregisterHook('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); + Addon::unregisterHook('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); logger("removed openstreetmap"); } -function openstreetmap_alterheader($a, &$navHtml) { +function openstreetmap_alterheader($a, &$navHtml) +{ $addScriptTag = '' . "\r\n"; $a->page['htmlhead'] .= $addScriptTag; } @@ -42,14 +45,15 @@ function openstreetmap_alterheader($a, &$navHtml) { * * If an item has coordinates add link to a tile map server, e.g. openstreetmap.org. * If an item has a location open it with the help of OSM's Nominatim reverse geocode search. - * + * * @param mixed $a * @param array& $item */ function openstreetmap_location($a, &$item) { - if(! (strlen($item['location']) || strlen($item['coord']))) + if(! (strlen($item['location']) || strlen($item['coord']))) { return; + } /* * Get the configuration variables from the config. @@ -60,20 +64,24 @@ function openstreetmap_location($a, &$item) { */ $tmsserver = Config::get('openstreetmap', 'tmsserver'); - if(! $tmsserver) + if(! $tmsserver) { $tmsserver = 'http://www.openstreetmap.org'; + } $nomserver = Config::get('openstreetmap', 'nomserver'); - if(! $nomserver) + if(! $nomserver) { $nomserver = 'http://nominatim.openstreetmap.org/search.php'; + } $zoom = Config::get('openstreetmap', 'zoom'); - if(! $zoom) + if(! $zoom) { $zoom = 16; + } $marker = Config::get('openstreetmap', 'marker'); - if(! $marker) + if(! $marker) { $marker = 0; + } if ($item['coord'] != "") { $coords = explode(' ', $item['coord']); @@ -87,54 +95,59 @@ function openstreetmap_location($a, &$item) { } } - if ($target == "") + if ($target == "") { $target = $nomserver.'?q='.urlencode($item['location']); + } - if ($item['location'] != "") + if ($item['location'] != "") { $title = $item['location']; - else + } else { $title = $item['coord']; + } $item['html'] = ''.$title.''; } -function openstreetmap_generate_named_map(&$a,&$b) { - - +function openstreetmap_generate_named_map(&$a, &$b) +{ $nomserver = Config::get('openstreetmap', 'nomserver'); if(! $nomserver) $nomserver = 'http://nominatim.openstreetmap.org/search.php'; $args = '?q=' . urlencode($b['location']) . '&format=json'; - $x = z_fetch_url($nomserver . $args); + $x = Network::curl($nomserver . $args); if($x['success']) { $j = json_decode($x['body'],true); if($j && is_array($j) && $j[0]['lat'] && $j[0]['lon']) { - $arr = array('lat' => $j[0]['lat'],'lon' => $j[0]['lon'],'location' => $b['location'], 'html' => ''); + $arr = ['lat' => $j[0]['lat'],'lon' => $j[0]['lon'],'location' => $b['location'], 'html' => '']; openstreetmap_generate_map($a,$arr); $b['html'] = $arr['html']; } } } -function openstreetmap_generate_map(&$a,&$b) { - +function openstreetmap_generate_map(&$a, &$b) +{ $tmsserver = Config::get('openstreetmap', 'tmsserver'); - if(! $tmsserver) + if(! $tmsserver) { $tmsserver = 'http://www.openstreetmap.org'; - if(strpos(z_root(),'https:') !== false) + } + if(strpos(z_root(),'https:') !== false) { $tmsserver = str_replace('http:','https:',$tmsserver); + } $zoom = Config::get('openstreetmap', 'zoom'); - if(! $zoom) + if (!$zoom) { $zoom = 16; + } $marker = Config::get('openstreetmap', 'marker'); - if(! $marker) + if (!$marker) { $marker = 0; + } $lat = $b['lat']; // round($b['lat'], 5); $lon = $b['lon']; // round($b['lon'], 5); @@ -145,36 +158,42 @@ function openstreetmap_generate_map(&$a,&$b) { $b['html'] = '
' . (($b['location']) ? escape_tags($b['location']) : t('View Larger')) . ''; + $b['html'] .= '&layer=mapnik&marker=' . $lat . '%2C' . $lon . '" style="border: 1px solid black">
' . (($b['location']) ? escape_tags($b['location']) : L10n::t('View Larger')) . ''; logger('generate_map: ' . $b['html'], LOGGER_DATA); - } -function openstreetmap_plugin_admin(&$a, &$o) { +function openstreetmap_addon_admin(&$a, &$o) +{ $t = get_markup_template("admin.tpl", "addon/openstreetmap/"); $tmsserver = Config::get('openstreetmap', 'tmsserver'); - if(! $tmsserver) + if (!$tmsserver) { $tmsserver = 'http://www.openstreetmap.org'; + } $nomserver = Config::get('openstreetmap', 'nomserver'); - if(! $nomserver) + if (!$nomserver) { $nomserver = 'http://nominatim.openstreetmap.org/search.php'; + } $zoom = Config::get('openstreetmap', 'zoom'); - if(! $zoom) + if (!$zoom) { $zoom = 16; + } $marker = Config::get('openstreetmap', 'marker'); - if(! $marker) + if (!$marker) { $marker = 0; + } - $o = replace_macros($t, array( - '$submit' => t('Submit'), - '$tmsserver' => array('tmsserver', t('Tile Server URL'), $tmsserver, t('A list of public tile servers')), - '$nomserver' => array('nomserver', t('Nominatim (reverse geocoding) Server URL'), $nomserver, t('A list of Nominatim servers')), - '$zoom' => array('zoom', t('Default zoom'), $zoom, t('The default zoom level. (1:world, 18:highest, also depends on tile server)')), - '$marker' => array('marker', t('Include marker on map'), $marker, t('Include a marker on the map.')), - )); + $o = replace_macros($t, [ + '$submit' => L10n::t('Submit'), + '$tmsserver' => ['tmsserver', L10n::t('Tile Server URL'), $tmsserver, L10n::t('A list of public tile servers')], + '$nomserver' => ['nomserver', L10n::t('Nominatim (reverse geocoding) Server URL'), $nomserver, L10n::t('A list of Nominatim servers')], + '$zoom' => ['zoom', L10n::t('Default zoom'), $zoom, L10n::t('The default zoom level. (1:world, 18:highest, also depends on tile server)')], + '$marker' => ['marker', L10n::t('Include marker on map'), $marker, L10n::t('Include a marker on the map.')], + ]); } -function openstreetmap_plugin_admin_post(&$a) { + +function openstreetmap_addon_admin_post(&$a) +{ $urltms = ((x($_POST, 'tmsserver')) ? notags(trim($_POST['tmsserver'])) : ''); $urlnom = ((x($_POST, 'nomserver')) ? notags(trim($_POST['nomserver'])) : ''); $zoom = ((x($_POST, 'zoom')) ? intval(trim($_POST['zoom'])) : '16'); @@ -183,7 +202,5 @@ function openstreetmap_plugin_admin_post(&$a) { Config::set('openstreetmap', 'nomserver', $urlnom); Config::set('openstreetmap', 'zoom', $zoom); Config::set('openstreetmap', 'marker', $marker); - info( t('Settings updated.') . EOL); + info(L10n::t('Settings updated.') . EOL); } - -