Geo Localizer packager for WP Bones

Latest Stable VersionLatest Unstable VersionTotal DownloadsLicenseMonthly DownloadsGitHubCHANGELOG

Geo Localizer provides a set of utilities to manage geolocation for WordPress/WP Bones

Requirements

This package works with a WordPress plugin written with WP Bones framework library.

Installation

You can install third party packages by using:

php bones require wpbones/geolocalizer

I advise to use this command instead of composer require because doing this an automatic renaming will done.

You can use composer to install this package:

composer require wpbones/geolocalizer

You may also to add "wpbones/geolocalizer": "^1.0" in the composer.json file of your plugin:

composer.json
  "require": {
    "php": ">=7.4",
    "wpbones/wpbones": "~1.5",
    "wpbones/geolocalizer": "~1.0"
  },

and run

composer install

Alternatively, you can get the single files src/resources/assets/js/actions-and-filters.js in your WP Bones plugin and compile it with gulp. Also, you can get pre-compiled minified version src/public/js/actions-and-filters.min.js.

Migration

In the database/migrations you’ll find the default migration database table used for the countries. Also. in the database/seeders you’ll find the data for countries database table.

Anyway, you just copy these folders in your plugin database/ folder.

Geo services

This version is using the IPStack service to get the country code and the rest of the data. You have to create an account in IPStack and get your API key. In your plugin you may use the API key b yusing the filter:

add_filter('wpbones_geolocalizer_ipstack_api_key', function () {
    // get your api key rom your settings
    // for example, MyPlugin::$plugin->options->get('General/ipstack_api_key');
    return $your_api_key;
});

Testing

In order to check if your API key is valid you can use the following command:

$info = MyPlugin\GeoLocalizer\GeoLocalizerProvider::geoIP();

You should receive all information starting from your IP address. Otherwise, you’ll receive an error from IPStack service.

Shortcode

Geolocalizer provides a shortcode method. You can define you own shortcode in the your shortcode provider class:

use WPMyPlugin\WPBones\Foundation\WordPressShortcodesServiceProvider as ServiceProvider;
use WPMyPlugin\GeoLocalizer\GeoLocalizerProvider;
 
class WPMyPluginShortcode extends ServiceProvider
{
 
  /**
   * List of registred shortcodes. {shortcode}/method
   *
   * @var array
   */
  protected $shortcodes = [
    'my_shortocde_geo' => 'my_shortocde_geo',
  ];
 
 
  public function my_shortocde_geo( $atts = [], $content = null )
  {
    return GeoLocalizerProvider::shortcode( $atts, $content );
  }
 

The you can use:

[my_shortocde_geo city="Rome"]
  Only for Rome
[/my_shortocde_geo]
[my_shortocde_geo city="rome"]
  Only for Rome
[/my_shortocde_geo]
[my_shortocde_geo city="rome,london"]
  Only for Rome and Landon
[/my_shortocde_geo]
[my_shortocde_geo region_name="lazio"]
  Only for region (Italy) Lazio
[/my_shortocde_geo]
[my_shortocde_geo country_code="IT"]
  Italian only
[/my_shortocde_geo]
[my_shortocde_geo country_name="italy"]
  Italian only
[/my_shortocde_geo]
[my_shortocde_geo zip_code="00137"]
  Wow
[/my_shortocde_geo]
[my_shortocde_geo ip="80.182.82.82"]
  Only for me
[/my_shortocde_geo]
[my_shortocde_geo time_zone="europe\rome"]
  Rome/Berlin time zone
[/my_shortocde_geo]