robole/sulu-ai-translator-bundle

Translate any type of content using DeepL

Installs: 551

Dependents: 0

Suggesters: 0

Security: 0

Stars: 17

Watchers: 3

Forks: 4

Open Issues: 0

Language:JavaScript

Type:symfony-bundle

pkg:composer/robole/sulu-ai-translator-bundle

v1.1.1 2025-04-24 13:38 UTC

This package is auto-updated.

Last update: 2025-10-13 07:47:59 UTC


README

SuluAITranslatorBundle

Sulu bundle that integrates DeepL API for bulk and single translations of content fields.

GitHub release Supports Sulu 2.6 or later

Demonstration of content field translation

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.

  1. Open a command console, enter your project directory and run:
composer require robole/sulu-ai-translator-bundle

If you're not using Symfony Flex, you'll also need to add the bundle in your config/bundles.php file:

return [
    //...
    Robole\SuluAITranslatorBundle\SuluAITranslatorBundle::class => ['all' => true],
];
  1. Register the new routes by adding the following to your routes_admin.yaml:
SuluAITranslatorBundle:
    resource: "@SuluAITranslatorBundle/Resources/config/routes_admin.yml"
  1. Add the file config/packages/sulu_ai_translator.yaml with the following configuration:
sulu_ai_translator:
    deepl_api_key: "%env(DEEPL_API_KEY)%"
    locale_mapping:
        en: "en-GB"

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.

  1. Reference the frontend code by adding the following to your assets/admin/package.json:
"dependencies": {
    "sulu-ai-translator-bundle": "file:../../vendor/robole/sulu-ai-translator-bundle/src/Resources/js"
}
  1. Import the frontend code by adding the following to your assets/admin/app.js:
import "sulu-ai-translator-bundle";
  1. Install all npm dependencies and build the admin UI (see all options):
cd assets/admin
npm install
npm run build
  1. Add your Deepl API Key to the .env file:
DEEPL_API_KEY="..."
  1. 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

  1. Add to repositories section of composer.json:
    "repositories": [
        {
            "type": "path",
            "url": "./../local-path-to-bundle"
        }
    ],
  1. 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.