jield-webdev / jield-slm-locale
Automatic detection of locales for Laminas
Requires
- php: ^5.6 || ^7.0
- ext-intl: *
- zendframework/zend-eventmanager: ^3.1
- zendframework/zend-http: ^2.7
- zendframework/zend-modulemanager: ^2.8.1
- zendframework/zend-router: ^3.0
- zendframework/zend-servicemanager: ^3.2
- zendframework/zend-stdlib: ^3.1
- zendframework/zend-view: ^2.9.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.8.1
- phpunit/phpunit: ^4.8.36
- satooshi/php-coveralls: ^1.0.2
- zendframework/zend-console: ^2.6
- zendframework/zend-mvc: ^3.1
- zendframework/zend-mvc-console: ^1.1.9
Suggests
- zendframework/zend-mvc: For using the router in the UriPath strategy
This package is auto-updated.
Last update: 2024-09-09 00:49:55 UTC
README
Created by Jurian Sluiman
Introduction
SlmLocale is a Laminas module to automatically detect a locale for your application. It uses a variety of pluggable strategies to search for a valid locale. SlmLocale features a default locale, a set of supported locales and locale aliases.
SlmLocale supports out of the box several strategies to search for a locale. Through interfaces, other strategies could be created. The set of default stragies is:
- The HTTP
Accept-Language
header - A cookie to store the locale between several sessions of one visitor
- A query parameter to easily switch from locale
- The first segment of the path of an uri
- A part of the domain name (either the TLD or a subdomain)
Furthermore, it provides a set of additional localisation features:
- A default locale, used as fallback
- A set of aliases, so you can map
.com
as "en-US" in the host name strategy - Redirect to the right domain/path when a locale is found
- View helpers to create a localised uri or a list of language switches
Installation
Add "slm/locale" to your composer.json file and update your dependencies. Enable
SlmLocale in your application.config.php
.
If you do not have a composer.json file in the root of your project, copy the
contents below and put that into a file called composer.json
and save it in
the root of your project:
{
"require": {
"slm/locale": ">=0.1.0,<1.2.0-dev"
}
}
Then execute the following commands in a CLI:
curl -s http://getcomposer.org/installer | php
php composer.phar install
Now you should have a vendor
directory, including a slm/locale
. In your
bootstrap code, make sure you include the vendor/autoload.php
file to properly
load the SlmLocale module.
Usage
Set your default locale in the configuration:
'slm_locale' => [
'default' => 'nl-NL',
],
Set all your supported locales in the configuration:
'slm_locale' => [
'supported' => ['en-US', 'en-GB'],
],
And enable some strategies. The naming is made via the following list:
- cookie:
SlmLocale\Strategy\CookieStrategy
- host:
SlmLocale\Strategy\HostStrategy
- acceptlanguage:
SlmLocale\Strategy\HttpAcceptLanguageStrategy
- query:
SlmLocale\Strategy\QueryStrategy
- uripath:
SlmLocale\Strategy\UriPathStrategy
- asset:
SlmLocale\Strategy\AssetStrategy
You can enable one or more of them in the strategies
list. Mind the priority
is important! You usually want the acceptlanguage
as last for a fallback:
'slm_locale' => [
'strategies' => ['uripath', 'acceptlanguage'],
],
At this moment, the locale should be detected. The locale is stored inside php's
Locale
object. Retrieve the locale with Locale::getDefault()
. This is also
automated inside Laminas translator objects and i18n view helpers (so
you do not need to set the locale yourself there).
Set the locale's language in html
It is common to provide the html with the used locale. This can be set for example
in the html
tag:
<html lang="en">
Inject the detected language here with the following code:
<html lang="<?= $this->primaryLanguage()?>">
Disable UriPathStrategy in PHPUNIT
This is necessary (at the moment) if you want to use this->dispatch('my/uri');
in your AbstractHttpControllerTestCase
unit tests.
Otherwise, if you check for responseCode you will get 302
where it should be 200
.
Example:
$this->dispatch('/to/my/uri');
$this->assertResponseStatusCode(200); // this will be 302 instead of 200
$this->dispatch('/en/to/my/uri');
$this->assertResponseStatusCode(200); // this will be 302 instead of 200
To fix add the following to your phpunit config.
phpunit.xml:
<phpunit...>
...
<php>
<server name="DISABLE_URIPATHSTRATEGY" value="true" />
</php>
</phpunit>
Or set $_SERVER['DISABLE_URIPATHSTRATEGY'] = true;
in your bootstrap file of phpunit.
Create a list of available locales
T.B.D
Read more about usage and the configuration of all the strategies in the documentation.