Download the PHP package robole/sulu-ai-translator-bundle without Composer
On this page you can find all versions of the php package robole/sulu-ai-translator-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download robole/sulu-ai-translator-bundle
More information about robole/sulu-ai-translator-bundle
Files in robole/sulu-ai-translator-bundle
Package sulu-ai-translator-bundle
Short Description Translate any type of content using DeepL
License MIT
Homepage https://github.com/robole-dev/sulu-ai-translator-bundle
Informations about the package sulu-ai-translator-bundle
AITranslatorBundle
Sulu bundle that integrates DeepL API for bulk and single translations of content fields.
AITranslatorBundle features:
- DeepLService to fetch translations and usage statistics from DeepL API
- "Usage statistics" admin view with permission
- Translation button next to input fields
- Toolbar button to bulk translate all fields (currently only for pages, snippets and forms)
Installation
This bundle requires PHP 8.2. Make sure to have installed Node 18 (or Node 14 for Sulu versions <2.6.0) for building the Sulu administration UI.
- Open a command console, enter your project directory and run:
If you're not using Symfony Flex, you'll also need to add the bundle in your config/bundles.php
file:
-
Register the new routes by adding the following to your
routes_admin.yaml
: - Add the file
config/packages/sulu_ai_translator.yaml
with the following configuration:
Via locale_mapping
you can map a locale key from your webspace to the according official DeepL target language. Use value null
for languages that should not be translatable.
-
Reference the frontend code by adding the following to your
assets/admin/package.json
: -
Import the frontend code by adding the following to your
assets/admin/app.js
: -
Install all npm dependencies and build the admin UI (see all options):
-
Add your Deepl API Key to the
.env
file: - Grant permissions in Sulu backend to access "DeepL Usage Statistics" view.
Limitations
- Currently only supports fields of type
input[type="text"]
,textarea
and<CkEditor />
- Translations are applied on the frontend, giving content creators the ability to check translation quality and undo changes
- Links to internal pages within text fields have to be updated by hand (obviously)
Local development
-
Add to
repositories
section ofcomposer.json
: - Install bundle:
composer require robole/sulu-ai-translator-bundle:@dev
Troubleshooting
If a translation request returns the input text, it is very likely that the language key(s) defined in your locale_mapping
bundle configuration are not supported by DeepL. This will be indicated in the response object.
Ideas for next versions
- Add Symfony Recipe for quicker installation of bundle.
- Replace
document.querySelector
with store-based approach for toggling blocks. - Enable configuration of translation strictness for each language (e.g. formal, informal, etc.)
- Add a dropdown popup next to translation button for overwriting source and target language of a field
Disclaimer
This bundle uses the DeepL API to provide translation services. This project is not affiliated, associated, authorized, endorsed by, or in any way officially connected with DeepL SE or any of its subsidiaries or affiliates. The use of the DeepL API in this bundle is purely for functionality purposes and does not imply any relationship with the DeepL company.
DeepL is a registered trademark of DeepL SE.
All versions of sulu-ai-translator-bundle with dependencies
sulu/sulu Version ^2.5
symfony/config Version ^6.2 | ^7.0
symfony/dependency-injection Version ^6.2 | ^7.0
symfony/framework-bundle Version ^6.2 | ^7.0
symfony/http-foundation Version ^6.2 | ^7.0
symfony/http-kernel Version ^6.2 | ^7.0
symfony/intl Version ^6.2 | ^7.0
symfony/translation Version ^6.2 | ^7.0
symfony/security-core Version ^6.3 | ^7.0
deeplcom/deepl-php Version ^1.7