Download the PHP package lukasss93/laravel-larex without Composer
On this page you can find all versions of the php package lukasss93/laravel-larex. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download lukasss93/laravel-larex
More information about lukasss93/laravel-larex
Files in lukasss93/laravel-larex
Package laravel-larex
Short Description Translate your Laravel application from a single CSV file!
License MIT
Informations about the package laravel-larex
Laravel Larex
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.
🚀 Installation
You can install the package using composer
Then add the service provider to config/app.php.
This step can be skipped if package auto-discovery is enabled.
⚙ Publishing the config file
Publishing the config file is optional:
👓 Usage
-
First, you must create the initial CSV file with
php artisan larex:init.
Or you can usephp artisan larex:importto import entries from lang folder.
The csv file has the following columns:- group (basically the file name)
- key (the array key)
- en (the language code)
- other language codes...
-
Open the project-root/lang/localization.csv file and edit it as you see fit.
- Finally, you can use
php artisan larex:exportto translate your entries from the csv file to the laravel php files.
✨ Tips
- You can import existing laravel php files with
php artisan larex:import. - You can use
php artisan larex:init --baseto init the CSV file with default Laravel entries. - The key column inside the CSV file supports the dot notation for nested arrays.
- You can watch your CSV file with
php artisan larex:export --watch - You can use
php artisan larex:sortto sort the CSV file by group and key. - Be careful when using the
php artisan larex:exportcommand! It will overwrite all files named with the group names inside the CSV. - Be careful when using the dot notation! Only the last entry will override the value.
- You can use
php artisan larex:insertto add new items via CLI too! - You can use
php artisan larex:import --include=en,itto import only "en" and "it" items. - You can use
php artisan larex:import --exclude=itto import all items except "it" item. - You can use
php artisan larex:export --include=en,itto export only "en" and "it" columns. - You can use
php artisan larex:export --exclude=itto export all columns except "it" column. - You can use
php artisan larex:localizeto find unlocalized strings (use the--importoption to add strings in your CSV). - You can use
php artisan larex:findto search existing groups or keys in your CSV file. - You can use
php artisan larex:removeto remove existing strings in your CSV file. - You can use
php artisan larex:lang:addto add a new language column to your CSV file. - You can use
php artisan larex:lang:removeto remove a language column from your CSV file. - You can use
php artisan larex:lang:orderto reorder language columns in your CSV file.
📝 Example
-
Run
php artisan larex:initcommand - 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:exportcommand - You'll get the following files:
⏫ Exporters
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 |
How to create an exporter:
- Create a class that implements the
Lukasss93\Larex\Contracts\Exporterinterface - Add your exporter inside the larex config
⏬ Importers
The 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 |
How to create an importer:
- Create a class that implements the
Lukasss93\Larex\Contracts\Importerinterface - Add your importer inside the larex config
🔍 Linters
Larex provides a linting system by using the php artisan larex:lint command to validate your CSV file.
Available linters:
| Linter | Enabled by 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.
How to create a linter:
- Create a class that implements the
Lukasss93\Larex\Contracts\Linterinterface - Add your linter inside the larex config
🧩 Plugins
- Crowdin Plugin
A Laravel Larex plugin to import/export localization strings from/to Crowdin
⚗️ Testing
🔰 Version Support
| Larex | L5.8 | L6.x | L7.x | L8.x | L9.x | L10.x | L11.x | L12.x | L13.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 | PHP8.4 | PHP8.5 |
|---|---|---|---|---|---|---|---|---|---|
| ^1.0 | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ | ❌ | ❌ |
| ^1.6 | ^2.0 | ❌ | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ | ❌ | ❌ |
| ^3.0 | ❌ | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | ❌ | ❌ |
| ^4.0 | ❌ | ❌ | ❌ | ✅ | ✅ | ✅ | ✅ | ✅ | ✅ |
📃 Changelog
Please see the CHANGELOG.md for more information on what has changed recently.
🏅 Credits
📖 License
Please see the LICENSE.md file for more information.
All versions of laravel-larex with dependencies
ext-dom Version *
ext-json Version *
illuminate/support Version ^8.0|^9.0|^10.0|^11.0|^12.0|^13.0
loilo/fuse Version ^6.4.6|^7.1
spatie/simple-excel Version ^3.0.1
spatie/laravel-collection-macros Version ^7.12|^8.0