Package Data | |
---|---|
Maintainer Username: | Lukasss93 |
Maintainer Contact: | lucapatera@outlook.it (Luca Patera) |
Package Create Date: | 2020-06-29 |
Package Last Update: | 2024-08-01 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-29 15:00:04 |
Package Statistics | |
---|---|
Total Downloads: | 36,892 |
Monthly Downloads: | 2,632 |
Daily Downloads: | 32 |
Total Stars: | 96 |
Total Watchers: | 5 |
Total Forks: | 7 |
Total Open Issues: | 3 |
Laravel Larex lets you translate your whole Laravel application with a single CSV file.
You can import translation entries from lang folder into a structured CSV, edit the translations and export them back to Laravel PHP files.
Laravel Larex also supports functionalities to sort entries and find strings that aren't localized yet.
See Plugins section for other features.
You can install the package using composer
composer require lukasss93/laravel-larex --dev
Then add the service provider to config/app.php
.
This step can be skipped if package auto-discovery is enabled.
'providers' => [
Lukasss93\Larex\LarexServiceProvider::class
];
Publishing the config file is optional:
php artisan vendor:publish --provider="Lukasss93\Larex\LarexServiceProvider" --tag="larex-config"
First, you must create the initial CSV file with php artisan larex:init
.
Or you can use php artisan larex:import
to import entries from lang folder.
The csv file has the following columns:
Open the project-root/lang/localization.csv file and edit it as you see fit.
Finally, you can use php artisan larex:export
to translate your entries from the csv file to the laravel php files.
php artisan larex:import
.php artisan larex:init --base
to init the CSV file with default Laravel entries.php artisan larex:export --watch
php artisan larex:sort
to sort the CSV file by group and key.php artisan larex:export
command! It will overwrite all files named with the group names
inside the CSV.php artisan larex:insert
to add new items via CLI too!php artisan larex:import --include=en,it
to import only "en" and "it" items.php artisan larex:import --exclude=it
to import all items except "it" item.php artisan larex:export --include=en,it
to export only "en" and "it" columns.php artisan larex:export --exclude=it
to export all columns except "it" column.php artisan larex:localize
to find unlocalized strings (use the --import
option to add strings in your
CSV).php artisan larex:find
to search existing groups or keys in your CSV file.php artisan larex:remove
to remove existing strings in your CSV file.php artisan larex:lang:add
to add a new language column to your CSV file.php artisan larex:lang:remove
to remove a language column from your CSV file.php artisan larex:lang:order
to reorder language columns in your CSV file.Run php artisan larex:init
command
Edit the project-root/lang/localization.csv file
| group | key | en | it | |-------|-----------------|------------|--------------| | app | hello | Hello | Ciao | | app | list.developers | Developers | Sviluppatori | | app | list.teachers | Teachers | Insegnanti |
Run php artisan larex:export
command
You'll get the following files:
//project-root/lang/en/app.php
<?php
return [
'hello' => 'Hello',
'list' => [
'developers' => 'Developers',
'teachers' => 'Teachers',
]
];
//project-root/lang/it/app.php
<?php
return [
'hello' => 'Ciao',
'list' => [
'developers' => 'Sviluppatori',
'teachers' => 'Insegnanti',
]
];
The larex:export <exporter>
command exports CSV strings to a specific location based on the selected exporter.
| Exporter | Default | Description | |------------|:-------:|----------------------------------------------------| | laravel | ✅ | Export data from CSV to Laravel localization files | | json:group | ❌ | Export data from CSV to JSON by group | | json:lang | ❌ | Export data from CSV to JSON by language |
Lukasss93\Larex\Contracts\Exporter
interfaceThe larex:import <importer>
command imports the strings of the selected importer, into the CSV.
| Importer | Default | Description | |------------|:---------:|----------------------------------------------------| | laravel | ✅ | Import data from Laravel localization files to CSV | | json:group | ❌ | Import data from JSON by group to CSV | | json:lang | ❌ | Import data from JSON by language to CSV |
Lukasss93\Larex\Contracts\Importer
interfaceLarex provides a linting system by using the php artisan larex:lint
command to validate your CSV file.
| Linter | Enabledby default | Description | |---------------------------|:---------------------:|---------------------------------------------------| | ValidHeaderLinter | ✅ | Validate the header structure | | ValidLanguageCodeLinter | ✅ | Validate the language codes in the header columns | | DuplicateKeyLinter | ✅ | Find duplicated keys | | ConcurrentKeyLinter | ✅ | Find concurrent keys | | NoValueLinter | ✅ | Find missing values | | DuplicateValueLinter | ✅ | Find duplicated values in the same row | | UntranslatedStringsLinter | ❌ | Find untranslated strings | | UntranslatedStringsLinter | ❌ | Find unused strings | | ValidHtmlValueLinter | ❌ | Check valid html values | | SameParametersLinter | ❌ | Check same parameters in each language |
You can enable/disable any linter you want by comment/uncomment it inside the larex config.
Lukasss93\Larex\Contracts\Linter
interfacecomposer test
| Larex | L5.8 | L6.x | L7.x | L8.x | L9.x | L10.x | L11.x | |:----------------:|:----:|:----:|:----:|:----:|:----:|:-----:|-------| | ^1.0 | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | | ^1.2 | ^2.0 | ❌ | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | | ^3.0 | ❌ | ❌ | ✅ | ✅ | ❌ | ❌ | ❌ | | ^4.0 | ❌ | ❌ | ❌ | ✅ | ✅ | ✅ | ✅ |
| Larex | PHP7.2 | PHP7.3 | PHP7.4 | PHP8.0 | PHP8.1 | PHP8.2 | PHP8.3 | |:----------------:|:------:|:------:|:------:|:------:|:------:|:------:|--------| | ^1.0 | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ | | ^1.6 | ^2.0 | ❌ | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ | | ^3.0 | ❌ | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | | ^4.0 | ❌ | ❌ | ❌ | ✅ | ✅ | ✅ | ✅ |
Please see the CHANGELOG.md for more information on what has changed recently.
Please see the LICENSE.md file for more information.