Package for convenient work with Laravel's localization features
Package for convenient work with Laravel's localization features and fast language files generation. Take a look at contributing.md to see a to do list.
$ composer require awes-io/localization-helper
In Laravel 5.5+, service provider and facade will be automatically registered. For older versions, follow the steps below:
Register service provider in
'providers' => [ // [...] AwesIO\LocalizationHelper\LocalizationHelperServiceProvider::class, ],
You may also register
'aliases' => [ // [...] 'LocalizationHelper' => AwesIO\LocalizationHelper\Facades\LocalizationHelper::class, ],
In order to edit default configuration you may execute:
php artisan vendor:publish --provider="AwesIO\LocalizationHelper\LocalizationHelperServiceProvider"
config/localizationhelper.php will be created.
Package registers global helper function
_p($file_key, $default, $placeholders):
_p('auth.login', 'Login'); // "Login"
It will create new localization file
auth.php (if it doesn't exist) and write second parameter as language string under
return [ "login" => "Login" ];
On second call with same file/key
_p('auth.login'), localization string will be returned, file will remain untouched.
Placeholders are also supported:
_p( 'mail.invitation', 'You’re invited to join :company company workspace', ['company' => 'Awesio'] );
If key is returned, it means that string already exists in localization file and you are trying to add new one using its value as an array.
// in localization file.php return [ "test" => "Test string" ]; _p('file.test.new', 'Test string'); // will return "file.test.new" _p('file.test_2.new', 'Test string'); // will return "Test string" // and modify localization file: return [ "test" => "Test string", "test_2" => [ "new" => "Test string" ] ];
Please see the changelog for more information on what has changed recently.
$ composer test
Please see contributing.md for details and a todolist.
If you discover any security related issues, please email firstname.lastname@example.org instead of using the issue tracker.