GithubHelp home page GithubHelp logo

enriquegf / laravel-lang-import-export Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ghbob/laravel-lang-import-export

1.0 0.0 0.0 41 KB

A Laravel package providing artisan commands to import and export language files from and to CSV

License: MIT License

PHP 100.00%

laravel-lang-import-export's Introduction

laravel-lang-import-export

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.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

laravel-lang-import-export's People

Contributors

bramdevries avatar enriquegf avatar ghbob avatar immucahit avatar lenssoft avatar lunkkun avatar paulkirow avatar ta-ppyszczek avatar

Stargazers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.