New in Symfony 6.1: Locale Switcher
April 14, 2022 • Published by Javier Eguiluz
Symfony 6.1 is backed by:
Warning: This post is about an unsupported Symfony version. Some of this information may be out of date. Read the most recent Symfony Docs.
Contributed by
Kevin Bond
in #45793.
Working with the locale in Symfony applications is simple. The locale is stored
in a request attribute called _locale
and used in the rest of the application.
Changing the locale (e.g. in multilingual applications via a list of languages
selectable by users) requires changing that request attribute in an early event listener.
However, sometimes you need to change the locale of the application dynamically just to run some code. Imagine an application that renders Twig templates of emails in different languages. You need to change the locale only to render those templates.
In Symfony 6.1 we're improving situations like this thanks to a new locale switcher.
The LocaleSwitcher
object/service allows you to change at once the locale of
all the services that are tagged with kernel.locale_aware
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
use Symfony\Component\Translation\LocaleSwitcher;
class SomeClass
{
public function __construct(
private LocaleSwitcher $localeSwitcher,
) {}
public function someMethod()
{
// you can get the current application locale like this:
$currentLocale = $this->localeSwitcher->getLocale();
// you can set the locale for the entire application like this:
// (from now on, the application will use 'fr' (French) as the
// locale; including the default locale used to translate Twig templates)
$this->localeSwitcher->setLocale('fr');
// you can also run some code with a certain locale, without
// changing the locale for the rest of the application
$this->localeSwitcher->runWithLocale('es', function() {
// e.g. render here some Twig templates using 'es' (Spanish) locale
});
// ...
}
}
Help the Symfony project!
As with any Open-Source project, contributing code or documentation is the most common way to help, but we also have a wide range of sponsoring opportunities.
Comments are closed.
To ensure that comments stay relevant, they are closed for old posts.
Thanks!