Laravel dynamic language switcher for web and api routes
alkhatibdev/language-switcher is a Laravel package for laravel dynamic language switcher for web and api routes.
It currently has 12 GitHub stars and 4.642 downloads on Packagist (latest version v0.0.2).
Install it with composer require alkhatibdev/language-switcher.
Discover more Laravel packages by alkhatibdev
or browse all Laravel packages to compare alternatives.
Last updated

Laravel dynamic language switcher for both web and API routes with various supported options.
request body/query keys, request headers keys, and route parameters names.composer require alkhatibdev/language-switcher
php artisan vendor:publish --tag=language-switcher-config
A language-switcher.php config file will be published on your configs directory. Feel free to read and override all these configurable parts, or stick with the defaults configs
Everything is set out of the box, start calling your routes with these supported options:
// Request query key/value
http://example.com/?lang=en
// Request magic keys
http://example.com/?en
// Also you can use the same above parameters with the body of POST or PUT
curl -X POST http://example.com/api/users
-d '{"lang": "en"}'
curl --header "Accept-Language: en" http://example.com/api/users
For given route: Route::get('/{locale}/home', [HomeController, 'home']);
http://example.com/en/home
Note
- All previous examples will ask the package to switch locale to'en'.
- Upcoming requests still remind this newly set locale.
By default, the package middleware is assigned globally to all your routes. However, you can disable assign_globally from the package config file, and assign middleware alias to all routes and route groups manually.
// config/language-switcher.php
'assign_globally' => false,
// routes/web.php
// Assign to individual route
Route::get('/{locale}/home', [HomeController, 'home'])->middleware(['switchlocale']);
// Assign to route group
Route::->middleware(['switchlocale'])->group(function () {
//
});
// app/Http/kernel.php
protected $middlewareGroups = [
'web' => [
// ...
'switchlocale',
],
'api' => [
// ...
'switchlocale',
],
];
By default, the package uses sessions to store the current locale, switched by a user, to keep the newly selected locale active for the next requests without a need to pass the locale in every request. However, if you want to stop this behavior, set enable_session to false.
// config/language-switcher.php
'enable_session' => false,
Language Switcher is open-sourced software licensed under the MIT license.