coffreo / js-translation-extractor
Extract translation from javascript source code
Installs: 33 119
Dependents: 2
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 5
Open Issues: 1
pkg:composer/coffreo/js-translation-extractor
Requires
- php: ^5.6 || ^7.0 || ^8.0
- symfony/finder: ^2.7 || ^3.0 || ^4.0 || ^5.0 || ^6.0
Requires (Dev)
- coffreo/php-cs-fixer-config: ^2.2
- symfony/phpunit-bridge: ^3.4 || ^4.0
This package is auto-updated.
Last update: 2025-10-10 23:51:14 UTC
README
By Coffreo
Javascript translations extractor for willdurand/js-translation-bundle
This package is a small project existing to store in one place wonderfuls regexps to properly export translations
strings & metas from javascript source files.
It can be used standalone, but it's main goal is to be used in :
Installation
- 
You only need to install this package manually for standalone usage and to integrate in your own translation extractor system: composer require coffreo/js-translation-extractor
- 
Using with Symfony JMSTranslationBundle see coffreo/jms-translation-js-extractor-bundleinstallation guide.
- 
Using with Symfony PHP Translation see coffreo/php-translation-js-extractor-bundleinstallation guide.
Features
- extracts following strings from javascript files like a pro
trans('MESSAGE', {param: 'foo'}, 'DOMAIN') // ^ 1st parameter is translation message // ^ 3rd parameter is translation domain transChoice('MESSAGE_WITH_PLURALS', 3, {param: 'foo'}, 'DOMAIN') // ^ 1st parameter is translation message // ^ 4th parameter is translation domain // others parameters aren't extracted because they are useless.
Note that this is the syntax used by js-translation-bundle
- allow string delimiters to be  "or'
- extracts multi-lines commands
Usage
use Coffreo\JsTranslationExtractor\Extractor\JsTranslationExtractor; use Coffreo\JsTranslationExtractor\Model\TranslationCollection; $extractor = new JsTranslationExtractor(); $translationCollection = new TranslationCollection(); $extractor->extract(<<<FILECONTENT import Translator from 'bazinga-translator'; export default () => Translator.trans('This is awesome', {}, 'foo'); export { bad: () => Translator.trans('This is ugly'); }; FILECONTENT , $translationCollection); $first = $translationCollection->first(); $first->getMessage(); // This is awesome $first->getLine(); // 3 $first->getContext(); // ['domain' => 'foo'] $second = $translationCollection->get(1); $second->getMessage(); // This is ugly $second->getLine(); // 5 $second->getContext(); // []
Found a bug
Please fill an issue with informations to reproduce bug.
If your translated strings are not extracted properly, please provide a sample failing string.
Development
- Clone repository
- Execute
make [install] # to init composer after install make test # to run test
TODO
- Find a way to add and extract desc/meaning values
License
This project is licensed under the MIT License - see the LICENSE file for details