eko / googletranslatebundle
A Symfony bundle to deals with Google Translate API
Installs: 36 989
Dependents: 0
Suggesters: 0
Security: 0
Stars: 43
Watchers: 5
Forks: 22
Open Issues: 2
Requires
- php: ^5.3|^7.0
- guzzlehttp/guzzle: ~5.0
- symfony/framework-bundle: ^2.0|^3.0
README
Features
- Detect language used for a string
- Translate a string from a source language to a target one
- Translate a string into a target language by using language auto-detection (consume 1 more API call)
- Retrieve all languages available on API and obtain language names in a given language
- Profile detector / translate / languages list API calls in the Symfony profiler!
Installation
Add the bundle to your composer.json
file:
{ "require" : { "eko/googletranslatebundle": "dev-master" } }
Add this to app/AppKernel.php
<?php public function registerBundles() { $bundles = array( ... new Eko\GoogleTranslateBundle\EkoGoogleTranslateBundle(), ); ... return $bundles; }
Configuration
Edit app/config.yml
The following configuration lines are required:
eko_google_translate: api_key: <your key api string>
Usages
Detect a string language
Retrieve the detector service and call the detect()
method:
$detector = $this->get('eko.google_translate.detector'); $value = $detector->detect('Hi, this is my string to detect!'); // This will return 'en'
Translate a string
Retrieve the translator service and call the translate()
method:
$translator = $this->get('eko.google_translate.translator'); $value = $translator->translate('Hi, this is my text to detect!', 'fr', 'en'); // This will return 'Salut, ceci est mon texte à détecter!'
Translate a string from unknown language (use detector)
Retrieve the translator service and call the translate()
method without the source (third) parameter:
$translator = $this->get('eko.google_translate.translator'); $value = $translator->translate('Hi, this is my text to detect!', 'fr'); // This will return 'Salut, ceci est mon texte à détecter!'
Translate multiple strings
Retrieve the translator service and call the translate()
method with an array of your strings:
$translator = $this->get('eko.google_translate.translator'); $value = $translator->translate(array('Hi', 'This is my second text to detect!'), 'fr', 'en'); // This will return the following array: // array( // 0 => 'Salut', // 1 => 'Ceci est mon second texte à détecter !', // )
Note that you can also use an "economic mode" to translate multiple strings in a single request which is better for your application performances.
Your translations will be concatenated in one single Google request. To use it, simply add true
to the last argument:
$translator = $this->get('eko.google_translate.translator'); $value = $translator->translate(array('Hi', 'This is my second text to detect!'), 'fr', 'en', true); // This will return the following array: // array( // 0 => 'Salut', // 1 => 'Ceci est mon second texte à détecter !', // )
Obtain all languages codes available
Retrieve the languages service and call the get()
method without any argument:
$languages = $this->get('eko.google_translate.languages')->get(); // This will return: // array( // array('language' => 'en'), // array('language' => 'fr'), // ... // )
Obtain all languages codes available with their names translated
Retrieve the languages service and call the get()
method with a target language argument:
$languages = $this->get('eko.google_translate.languages')->get('fr'); // This will return: // array( // array('language' => 'en', 'name' => 'Anglais'), // array('language' => 'fr', 'name' => 'Français'), // ... // )
Notice: this will consume a detector API call.