ufirst / lang-import-export
A Laravel package providing artisan commands to import and export language files from and to CSV.
Installs: 150 586
Dependents: 0
Suggesters: 0
Security: 0
Stars: 41
Watchers: 4
Forks: 41
Open Issues: 7
Requires
- php: >=7.3
- illuminate/support: ^8.0|^9.0|^10.0
- symfony/var-exporter: ^5.1|^6
This package is auto-updated.
Last update: 2024-10-24 20:42:59 UTC
README
This package provides artisan commands to import and export language files from and to CSV. This can be used to send translations to agencies that normally work with Excel-like files.
It turns some navigation.php file...
<?php return [ 'commands' => [ 'next' => 'Next', 'prev' => 'Previous', 'play' => 'Play', ] 'tips' => [ 'next' => 'Navigate to the next item', 'prev' => 'Navigate to the previous item', 'play' => 'Autoplay the slide show', ] ];
...to the following CSV...
key,en
navigation.commands.next,Next
navigation.commands.prev,Previous
navigation.commands.play,Play
navigation.tips.next,"Navigate to the next item"
navigation.tips.prev,"Navigate to the previous item"
navigation.tips.play,"Autoplay the slide show"
...and vice versa.
Installation
Laravel 8.* and above
composer require ufirst/lang-import-export:^8.1.0
Laravel 7.*
composer require ufirst/lang-import-export:^7.0.0
Finally add the following line to the providers
array of your app/config/app.php
file:
'providers' => [ /* ... */ 'UFirst\LangImportExport\LangImportExportServiceProvider' ]
Laravel 5.*
For Laravel 5.* checkout the legacy branch and require version ^5.1.2
The usage of the legacy version of this package is slightly different
As an alternative you can checkout the fork of this repository highsolutions/laravel-lang-import-export
Usage
The package currently provides two commands, one for exporting the files and one for importing them back:
Export
# export all locales with all groups to console php artisan lang-export:csv # export all locales with all groups to csv file php artisan lang-export:csv --output /some/file.csv # custom csv delimiter and enclosure php artisan lang-export:csv --delimiter=";" --enclosure='"' --output=/some/file.csv # export single locale php artisan lang-export:csv -l en --output=/some/path/translations-en.csv # export single translation group php artisan lang-export:csv -g navigation --output=/some/path/navigation-all-langs.csv
You can optionally pass the -l (locale) and the -g (group) as options. The group is the name of the langauge file without its extension. You may define options for your desired CSV format.
Import
# import translations from csv php artisan lang-import:csv /some/file.csv # import from custom csv format php artisan lang-import:csv --delimiter=";" --enclosure='"' --escape='\\' /some/file.csv # import and merge over existing translation file php artisan lang-import:csv --merge=true /some/file.csv
During import the locale is extracted from the first row of the CSV file. Translation groups are guessed from the translation keys e.g. navigation.tips.next is imported to navigation group
Changelog
8.1.1
- added support for laravel 10
- fixed deprecated warnings for PHP 8.2+
8.1.0
- added support for laravel 9
- dropped support below laravel 8
- automatic service provider and alias discovery
8.0.2
- merge imported csv with existing translations by adding --merge=true option to import command
8.0.1
- fix: header delimiter and enclosure did not respect the given options during export
8.0.0
- added support for Laravel 8.x
7.1.0
- automatically create translation files during import based on translation keys in csv
- formatted code (PSR-2)
7.0.0
- added support for laravel:^7.0.0
- added feature to export all locales and groups in a single run
- the import command will guess the locale and the translation group from the csv
- added symfony/var-exporter for new array syntax during the import command
5.1.2
- legacy version
- compatible with laravel:^5.4