zicht / messages-bundle
Zicht Messages bundle
Installs: 26 833
Dependents: 1
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 6
Requires
- php: ^8.0
- doctrine/dbal: ^2.13.1 || ^3
- doctrine/orm: ^2.5
- sonata-project/admin-bundle: ^4
- symfony/console: ^6.4
- symfony/finder: ^6.4
- symfony/yaml: ^6.4
Requires (Dev)
- phpunit/phpunit: ^9.6
Suggests
- google/cloud-translate: To use the TranslateCommand with batch-translations through the Google Translate API
- dev-release/8.x
- dev-release/7.x
- dev-release/4.x
- 8.0.0
- 7.1.1
- 7.1.0
- 7.0.1
- 7.0.0
- 6.0.4
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 5.3.2
- 5.3.1
- 5.2.2
- 5.2.1
- 5.2.0
- 5.1.0
- 5.0.5
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.1.3
- 4.1.2
- 4.1.1
- 4.1.0
- 4.0.2
- 4.0.1
- 4.0.0
- 3.1.1
- 3.1.0
- 3.0.0
- 2.5.8
- 2.5.7
- 2.5.6
- 2.5.5
- 2.5.4
- 2.5.3
- 2.5.2
- 2.5.1
- 2.5.0
- 2.4.6
- 2.4.5
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- 2.2.4
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.5
- 2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 1.3.2
- 1.3.1
- 1.3.0
- 1.2.1
- 1.2.0
- 1.1.0
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0
- dev-release/6.x
- dev-release/5.x
- dev-feature/fix-translations-filter
- dev-feature/rewire-loader--2
- dev-feature/rewire-loader
This package is auto-updated.
Last update: 2025-01-02 16:20:06 UTC
README
The ZichtMessagesBundle provides an Doctrine entity and admin screens for managing messages and have the database provide translations for message keys. Additionally, some console tools are available for your convenience.
Admin
The admin is based on the SonataAdminBundle.
Console tools
Some utility console tools are available.
zicht:messages:add
adds a message to the database cataloguezicht:messages:load
loads a translation file into the database cataloguezicht:messages:flush
flushes Symfony's translation cache
Installing
- Make sure the
translations/
directory is present in your project.- Using translations is/seems to be dependent on the order of scanned directories. By using this directory we assure we are the last in line, overwriting templates with database.
- Add the db file for each domain-locale combination, for instance: message.en.db
- Add a translation via the CMS.
- Clear the cache with
php app/console cache:clear
- All existing message states will be unknown, you need to update these once by running
zicht:messages:load --sync
Configure manual cache clear
Edit your zicht_admin.yml
and add:
zicht_admin: rc: messages: route: zicht_messages_rc_flush method: DELETE title: Clear translation cache button: Clear
Message state
The messages-bundle maintains a state for each message, this state can be either import, user, or unknown. You can configure z to import messages on every deploy by adding the following:
tasks:
deploy:
post:
- @messages.load_files
To ensure that the message state is properly updated, add the following to you z config:
messages:
overwrite_compatibility: false
Automatic translation
Leverage the zicht:message:translate
command with automatic translation through an API of choice.
Kickstart the usage by using the provided Google Translate API.
Setup
composer require google/cloud-translate
Configuration
Define the Google Translator as a service in your project. Your API key should be the private key from a service account (https://cloud.google.com/translate/docs/basic/setup-basic)
parameters: env(GOOGLE_API_KEY): '%kernel.root_dir%/config/your-google-api-key.json'
<service id="Zicht\Bundle\MessagesBundle\Translator\GoogleTranslator"> <argument key="$googleTranslateServiceAccount">%env(json:file:resolve:GOOGLE_API_KEY)%</argument> </service>
Add a CompilerPass
to register a BatchTranslatorInterface
on the MessageTranslator
:
use Zicht\Bundle\MessagesBundle\Translator\GoogleTranslator; use Zicht\Bundle\MessagesBundle\Translator\MessageTranslator; /** * {@inheritDoc} */ public function process(ContainerBuilder $container) { $container ->getDefinition(MessageTranslator::class) ->addMethodCall('setBatchTranslator', [new Reference(GoogleTranslator::class)]); }
Usage
In this example we have copied a .nl.yaml
to a es.yaml
and we are informing the command that the sourcelanguage is nl
and the
targetlanguage should be es
. As we have already renamed the file, only contents of this file will be rewritten.
php bin/console zicht:message:translate /dir/to/project/translations/validators.es.(yaml|xlf) --source=nl --target=es
Conditions
The targetlanguage (--target=xx
) is required for yaml
as it cannot be autodiscovered.
For xlf
we use the target-language
attribute inside the file, but can be forced by using the target-option as well.
Parameters in the translations are rewritten and not sent to the translation-api to prevent translating them. They should be in the format of %param%
, !param
or {param}
.
If your file is in xliff
, we only support 1.2
.
If your file is in yaml
, and has hierarchical contents, this will be lost and the file will be rewritten with single lines containing the full path to your translation.
Before
app: index: title: Abc
After
app.index.title: Abc
Maintainer(s)
- Boudewijn Schoon boudewijn@zicht.nl