Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sonofwinter/translationbundle
A Symfony 4/5 bundle to translate an entity
https://github.com/sonofwinter/translationbundle
php7 php8 symfony-bundle symfony4 symfony5 translation
Last synced: 17 days ago
JSON representation
A Symfony 4/5 bundle to translate an entity
- Host: GitHub
- URL: https://github.com/sonofwinter/translationbundle
- Owner: SonOfWinter
- License: mit
- Created: 2018-05-13T17:25:08.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-09-20T13:05:47.000Z (over 1 year ago)
- Last Synced: 2024-12-16T02:53:56.724Z (18 days ago)
- Topics: php7, php8, symfony-bundle, symfony4, symfony5, translation
- Language: PHP
- Homepage:
- Size: 80.1 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
TranslationBundle
-----------------Installation
============Open a command console, enter your project directory and execute:
```bash
$ composer require sonofwinter/translation-bundle
```Configuration
=============You can override sow_translation.available_locales parameter to a new list for set your available lang list
default is _[ 'en', 'fr', 'es', 'de', 'it' ]_By default a Translation entity class exists but you can create your translation entity class who extends AbstractTranslation
To use it, set the sow_translation.translation_class_name parameter to
```xml
App\Entity\YourTranslationClass
```Usage
=====Your translated entities must implements Translatable interface
Then define translated properties in your entity```php
/**
* @var string
* @Translate(key="firstname")
*/
private $firstname;/**
* @var string
* @Translate(key="lastname", setter="setOtherName")
*/
private $lastname;
```You can defined the key property for matching another name, if it's not, the property name is taken by default.
The setter property is used if you want to use another setter.
A TranslatableConfigurationException is throws if the setter doens't exist.New n V0.8
==========This bundle now require php >= 8.0
you can use attribute instead of annotation
```php
use SOW\TranslationBundle\Attribute\Translation;class MyClasse {
#[Translation(key: "firstname")]
private string $firstname = '';#[Translation(key: "lastname", setter: "setOtherName")]
private string $lastname = '';
}
```By default, the bundle use annotation method, you have to change configuration to use attributes
```yaml
sow_translation.translation_method: attribute
```If you want to override attribute class, don't forget to define it in configuration
```yaml
sow_translation.attribute_class_name: SOW\TranslationBundle\Attribute\Translation
```Translate
=========You can use some methods for translate an entity :
* _translate(Translatable $entity, string $lang)_ to translate the entity in $lang
* _translateForLangs(Translatable $entity, array $langs)_ to translate the entity in multiple languagesSet translations
================These methods is use for set translations :
* _setTranslationForLangAndValue(Translatable $translatable, string $lang, string $key, string $value)_ to set a single translation
* _setTranslationForLangAndValues(Translatable $translatable, string $lang, array $values)_ for set multiple values in one lang
* _setTranslations(Translatable $translatable, array $translations)_ for set multiple translation for multiple languagesRemove translations
===================These methods is use for remove translations :
* _removeByObjectKeyAndLang(Translatable $object, string $key, string $lang)_ remove a specific translation
* _removeAllForTranslatable(Translatable $object)_ remove all translation for object
* _removeAllByKey(string $key)_ remove all translation for property