pixelant/pxa-site-choice-recommendation

Suggest localized version of site depends on user location and user language.

Installs: 5 082

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 5

Forks: 0

Open Issues: 0

Type:typo3-cms-extension

v2.1.0 2021-03-24 12:26 UTC

This package is auto-updated.

Last update: 2024-08-24 20:26:41 UTC


README

What does it do?

Suggest localized version of site depends on user location and user language. It will show bar on top of the page with possibility to choose site language. Select box options are sorted by priority calculated by checking user location and accept language.

Note: To get option based on user location, a EventListner needs to be created in a separate extension.

How to install it

Like a regular extension you need to do a few steps.

  1. Composer install composer require pixelant/pxa-site-choice-recommendation
  2. Go to extension manager to isntall extension.
  3. Include TypoScript. There are two options to include:
    • Site choice recommendation - default configuration required for extension to work
    • Site choice JS and CSS assets - will include Js and Css libs

Extension plugins

Extension has two plugins:

  1. Choice bar extension - Loaded by ajax to propose user to change site version. Can't be added on a page.
  2. Site choice recommendation splash page - Use as page content in order to show for user ALL available choices. Just select corresponding site choice configuration in order to show it's options.

How to create site choice configuration

Create new record "Site Choice Configuration". It could be created in any storage folder. "Site Choice Configuration" tabs: Main "General" tab:

  • Name - just whatever you want
  • Connect to sites - choose rootpages where bar should appear
  • Max Items - maximum items in select box in bar
  • Splash pages links - splash page link for every root page. Each root page might have it's own splash page.

"Choices" tab include available site choices for bar and splash page. Each site choice require next configration fields:

  • Title - title of choice. It's text area because it could have different versions(localizations) of title. You could specify different localization versions each in new row in a format "Title text|locale":
Default title
Swedish title|sv_SE
Ukrainian title|uk_UA
  • Flag - flag icon to show in select box and splash page
  • Select country - select country. This field represents ISO code (for ex. "us" for USA). This code will be used when check if choice match by user IP. ISO codes
  • Select language - select language from list. This field represents short ISO code (for ex. "en" for English). This code will be used for check by user language.
  • Link - if choice target to external url
  • Language layer - if choice should lead to site langauge layer. Link need to be empty if language layer is used.

Expected results

After TypoScript is included and Site Choice Configuration is connected to root page, you should get bar with proposal of best matching country / region based on location. Note: bar will remain invisible in case you already has visited website localization version that best match you location/language.

Enable choices based on user location

Extension has "built in" support to suggest options based on user location.

To enable it, you will need to create a EventListner in a separate extension and also download GeoLite2-Country.mmdb from MaxMind, available from https://www.maxmind.com.

Example:

1. Registering the event listener

Following is an example of how to enable the IPDetecor.

In file your_extension_name/Configuration/Services.yaml file add following:

  VendorName\YourExtensionName\EventListener\IpDetectorFactoryEvent:
    tags:
      - name: event.listener
        identifier: 'yourExtensionNameIpDetectorFactoryEvent'
        event: Pixelant\PxaSiteChoiceRecommendation\Detector\Event\AddDetectorFactoryEvent
        after: acceptLanguageDetectorFactoryEvent

2. The event listener class

Create file your_extension_name/Classes/EventListener/IpDetectorFactoryEvent.php file add following:

<?php

declare(strict_types=1);

namespace VendorName\YourExtensionName\EventListener;

use Pixelant\PxaSiteChoiceRecommendation\Detector\Event\AddDetectorFactoryEvent;
use Pixelant\PxaSiteChoiceRecommendation\Detector\Factory\IpDetectorFactory;

/**
 * Adds IpDetector to Detectors.
 */
final class IpDetectorFactoryEvent
{
    public function __invoke(AddDetectorFactoryEvent $event)
    {
        // Add IP Detector.
        $event->addDetectorFactoryCreators(IpDetectorFactory::class);
        // Set path to GeoLite2-Country.mmdb.
        $GLOBALS['TYPO3_CONF_VARS']['EXTENSIONS']['pxa_site_choice_recommendation']['countryDbPath']
            = 'EXT:your_extension_name/Resources/Private/GeoIp2/GeoLite2-Country.mmdb';
    }
}

3. GeoLite2-Country dababase

Download GeoLite2-Country.mmdb from MaxMind and save in folder: your_extension_name/Resources/Private/GeoIp2/GeoLite2-Country.mmdb.