mirror of
https://github.com/Mibew/google-maps-plugin.git
synced 2024-11-15 00:34:18 +03:00
170 lines
5.2 KiB
PHP
170 lines
5.2 KiB
PHP
<?php
|
|
/*
|
|
* This file is a part of Mibew Google Maps Plugin.
|
|
*
|
|
* Copyright 2014 Dmitriy Simushev <simushevds@gmail.com>.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
/**
|
|
* @file The main file of Mibew:GoogleMaps plugin.
|
|
*/
|
|
|
|
namespace Mibew\Mibew\Plugin\GoogleMaps;
|
|
|
|
use Mibew\Asset\AssetManagerInterface;
|
|
use Mibew\EventDispatcher\EventDispatcher;
|
|
use Mibew\EventDispatcher\Events;
|
|
use Mibew\Plugin\PluginManager;
|
|
|
|
/**
|
|
* Provides an ability to view visitors at Google Maps.
|
|
*/
|
|
class Plugin extends \Mibew\Plugin\AbstractPlugin implements \Mibew\Plugin\PluginInterface
|
|
{
|
|
/**
|
|
* Class constructor.
|
|
*
|
|
* @param array $config List of the plugin config. The following options are
|
|
* supported:
|
|
* - 'api_key': string, Google Maps API key that should be used to render
|
|
* maps.
|
|
*/
|
|
public function __construct($config)
|
|
{
|
|
if (empty($config['api_key'])) {
|
|
trigger_error('Google API key cannot be empty', E_USER_WARNING);
|
|
|
|
return;
|
|
}
|
|
parent::__construct($config);
|
|
|
|
$this->initialized = true;
|
|
}
|
|
|
|
/**
|
|
* Defines necessary event listeners.
|
|
*/
|
|
public function run()
|
|
{
|
|
$dispatcher = EventDispatcher::getInstance();
|
|
$dispatcher->attachListener(Events::USERS_FUNCTION_CALL, $this, 'usersFunctionCallHandler');
|
|
$dispatcher->attachListener(Events::PAGE_ADD_JS, $this, 'pageAddJsHandler');
|
|
$dispatcher->attachListener(Events::PAGE_ADD_CSS, $this, 'pageAddCssHandler');
|
|
}
|
|
|
|
/**
|
|
* A handler for {@link \Mibew\EventDispatcher\Events::USERS_FUNCTION_CALL}.
|
|
*
|
|
* Provides an ability to use "googleMapsGetInfo" function at the client
|
|
* side.
|
|
*
|
|
* @see \Mibew\EventDispatcher\Events::USERS_FUNCTION_CALL
|
|
*/
|
|
public function usersFunctionCallHandler(&$function)
|
|
{
|
|
if ($function['function'] == 'googleMapsGetInfo') {
|
|
// An IP string can contain more than one IP address. For example it
|
|
// can be something like this: "x.x.x.x (x.x.x.x)". We need to
|
|
// use only first one.
|
|
$ips = explode(' ', $function['arguments']['ip'], 2);
|
|
$ip = filter_var($ips[0], FILTER_VALIDATE_IP);
|
|
if (!$ip) {
|
|
// There is no valid IP in the string. An error should be returned.
|
|
$function['results'] = array(
|
|
'errorCode' => 1,
|
|
'errorMessage' => 'The specified IP is invalid!',
|
|
);
|
|
|
|
return;
|
|
}
|
|
$info = PluginManager::getInstance()
|
|
->getPlugin('Mibew:GeoIp')
|
|
->getGeoInfo($ip, get_current_locale());
|
|
|
|
$function['results'] = array(
|
|
'country' => $info['country_name'] ?: '',
|
|
'city' => $info['city'] ?: '',
|
|
'latitude' => $info['latitude'],
|
|
'longitude' => $info['longitude'],
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds custom JS files to the page.
|
|
*
|
|
* @see \Mibew\EventDispatcher\Events::PAGE_ADD_JS
|
|
*/
|
|
public function pageAddJsHandler(&$args)
|
|
{
|
|
if ($args['request']->attributes->get('_route') == 'users') {
|
|
$filepath = str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath());
|
|
$args['js'][] = $filepath . '/vendor/jquery-colorbox/jquery.colorbox-min.js';
|
|
$args['js'][] = array(
|
|
'content' => $this->getApiUrl(),
|
|
'type' => AssetManagerInterface::ABSOLUTE_URL,
|
|
);
|
|
$args['js'][] = $filepath . '/js/plugin.js';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Adds custom CSS files to the page.
|
|
*
|
|
* @see \Mibew\EventDispatcher\Events::PAGE_ADD_CSS
|
|
*/
|
|
public function pageAddCssHandler(&$args)
|
|
{
|
|
if ($args['request']->attributes->get('_route') == 'users') {
|
|
$filepath = str_replace(DIRECTORY_SEPARATOR, '/', $this->getFilesPath());
|
|
$args['css'][] = $filepath . '/vendor/jquery-colorbox/example3/colorbox.css';
|
|
$args['css'][] = $filepath . '/css/styles.css';
|
|
}
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public static function getVersion()
|
|
{
|
|
return '1.1.1';
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public static function getDependencies()
|
|
{
|
|
return array('Mibew:GeoIp' => '1.*');
|
|
}
|
|
|
|
/**
|
|
* Builds URL for Google Maps API.
|
|
*
|
|
* @return string API URL
|
|
* @throws \RuntimeException if API key was not set correctly.
|
|
*/
|
|
protected function getApiUrl()
|
|
{
|
|
if (empty($this->config['api_key'])) {
|
|
throw new \RuntimeException('Google API key cannot be empty');
|
|
}
|
|
|
|
return '//maps.googleapis.com/maps/api/js?key='
|
|
. $this->config['api_key']
|
|
. '&sensor=false';
|
|
}
|
|
}
|