tailrdigital / sulu-translations-bundle
Installs: 2 538
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 2
Forks: 2
Open Issues: 0
Type:symfony-bundle
Requires
- php: ~8.1.0 || ~8.2.0 || ~8.3.0
- azjezz/psl: ^2.6 || ^3.0
- doctrine/dbal: ^3.6
- jackalope/jackalope-doctrine-dbal: ^1.7 || ^2.0
- ramsey/uuid: ^4.7
- sulu/sulu: ^2.5
- symfony/clock: ^6.0 || ^7.0
- symfony/config: ^6.0 || ^7.0
- symfony/console: ^6.0 || ^7.0
- symfony/dependency-injection: ^6.0 || ^7.0
- symfony/http-foundation: ^6.0 || ^7.0
Requires (Dev)
- php-cs-fixer/shim: ^3.58
- php-standard-library/psalm-plugin: ^2.3
- phpro/symfony-conventions: ^1.5
- phpspec/prophecy-phpunit: ^2.1
- phpunit/phpunit: ^9.6
- psalm/plugin-symfony: ^5.1
- vimeo/psalm: ^5.24
- weirdan/doctrine-psalm-plugin: ^2.9
README
This package provides a Sulu admin panel for managing your website translations.
The package includes a custom Symfony translation provider which stores your translations in a database.
Demo
sulu-translations-bundle-demo.mov
Installation
composer require tailrdigital/sulu-translations-bundle
Register the bundle
Make sure the bundle is activated in config/bundles.php
:
Tailr\SuluTranslationsBundle\SuluTranslationsBundle::class => ['all' => true]
Register new admin routes
You need to manually register the failed queue admin controller routes in the file config/routes_admin.yaml
.
# config/routes_admin.yaml tailr_translations: resource: '@SuluTranslationsBundle/Presentation/Controller/Admin' type: attribute prefix: /admin/api
Add node dependency
Register an additional module in your admin's node dependencies via assets/admin/package.json
:
{ "dependencies": { "sulu-translations-bundle": "file:../../vendor/tailrdigital/sulu-translations-bundle/assets/admin" } }
Make sure to load the additional node module in your admin's assets/admin/index.js
or assets/admin/app.js
file:
import 'sulu-translations-bundle';
Recompile your admin assets
cd /app/assets/admin
npm install
npm run watch
Configuration
Configuring the provider
You have to add the database provider to the Symfony translator configuration. This is an example configuration for the config/packages/translation.yaml
file.
# config/packages/translation.yaml framework: translator: providers: tailr_database: dsn: 'database://default' domains: [ 'messages' ] locales: [ 'en', 'fr', 'nl' ]
Doctrine DBAL connection
The hostname in the DSN is actually your Doctrine DBAL connection name: database://<dbal_connection_name>
.
If you want to store your translations in a separate database (preferred), you could configure a new DBAL connection and use the connection name in the DSN of the database translation provider.
If you are using your default DBAL connection you probably want to configure doctrine.dbal.schema_filter
so your migrations doesn't try to drop the tailr_translations
table.
doctrine: dbal: url: '%env(DATABASE_URL)%' schema_filter: '/^(?!(other_prefix_|tailr_translations))/'
Export format
If you want to export your translations via the administrator panel, you should define the format or extension which is used for your translation files.
# config/packages/sulu_translations.yaml sulu_translations: export_format: 'csv'
Permissions
Make sure you've set the correct permissions in the Sulu admin for this package. Go to Settings > User Roles and enable the permissions (tailr_translations) you need. Afterwards you could find the translations view/panel via Settings > Manage translations.
Usage
First make sure the database table tailr_translations
is created by running the command below.
bin/console tailr:sulu-translations:setup
If you don't have local translations files (e.g. CSV) you can generate them by using the command below.
bin/console translation:extract --force --domain=messages --format=csv <locale>
Once you have local translation files, you can export them to the database by using command below.
bin/console translation:push tailr_database
Next you can update the translations via the Sulu admin panel.
Once you are done, you can export the translations back to the translations files by using the command below or clicking the Export translations button via the Sulu admin panel.
bin/console translation:pull tailr_database --force --format csv
After pulling the translations, you may need to clear the cache(s).
bin/console cache:clear bin/websiteconsole cache:clear
Known limitations
Only tested and used with CSV and YAML format.