承接 itech-world/sulu-translator-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

itech-world/sulu-translator-bundle

最新稳定版本:v1.0.0

Composer 安装命令:

composer require itech-world/sulu-translator-bundle

包简介

DeepL translation integration for Sulu CMS 3.x admin interface

README 文档

README

Itech World logo

Translator Bundle for Sulu

Developed by Steeven THOMAS

GitHub license Sulu compatibility

SuluTranslatorBundle integrates DeepL automatic translation into the Sulu CMS 3.x admin interface. Translate your page and article content with a single click, directly from the edit form.

📂 Requirements

🛠️ Features

  • Per-field translation button on text_line, text_area and text_editor fields
  • Bulk "Translate all" button in the form toolbar to translate every text field at once
  • Auto-detection of the source language by DeepL
  • Target language automatically set to the locale selected in the admin dropdown
  • Undo button to revert a translation to the previous value
  • HTML preservation for rich text fields (CKEditor content)
  • DeepL usage statistics page in admin settings (account type, billing period, character usage)
  • Permission-based access to the statistics page via Sulu role system
  • Pages and articles support

🇬🇧 Available translations

  • English
  • French
  • German

📦 Dependencies

📝 Installation

Composer

composer require itech-world/sulu-translator-bundle

Symfony Flex

If you don't use Symfony Flex, you can add the bundle to your config/bundles.php file:

return [
    // ...
    ItechWorld\SuluTranslatorBundle\ItechWorldSuluTranslatorBundle::class => ['all' => true],
];

Configuration

Step 1: Configure your DeepL API key

Add your DeepL API key to your .env or .env.local file:

DEEPL_API_KEY=your_deepl_api_key_here

Step 2: Create the bundle configuration

Create the file config/packages/itech_world_sulu_translator.yaml:

itech_world_sulu_translator:
    deepl_api_key: "%env(DEEPL_API_KEY)%"
    locale_mapping:
        en: "en-GB"
        fr: "fr"
        de: "de"

Note: The locale_mapping is optional. It maps Sulu locale codes to DeepL language codes. If a locale is not mapped, it will be converted to uppercase automatically (e.g. fr becomes FR). See DeepL supported languages for valid codes.

Step 3: Register the admin JavaScript

Edit the assets/admin/app.js to add the bundle in imports:

import 'sulu-itech-world-sulu-translator-bundle';

Step 4: BACK & Build admin assets

Edit the assets/admin/package.json to add the bundle to the list of bundles:

{
    "dependencies": {
        // ...
      "sulu-itech-world-sulu-translator-bundle": "file:../../vendor/itech-world/sulu-translator-bundle",
    }
}

In the assets/admin/ folder, run the following command:

npm install
npm run build

or

yarn install
yarn build

Step 5: Clear cache

php bin/adminconsole cache:clear

🔤 Per-field Translation

Once installed, a translate button (language icon) appears on every text_line, text_area and text_editor field in the page and article edit forms.

  1. Select the target language in the Sulu locale dropdown (top of the page)
  2. Click the translate button on any field
  3. The field content is sent to DeepL and replaced with the translation
  4. A green checkmark confirms the translation, and a red undo button appears next to it to revert to the original value

After translating individual fields, the green checkmark and red undo button are shown side by side:

Page with some fields translated — checkmark and undo buttons

🌍 Bulk Translation

A "Translate all" button is available in the form toolbar:

  1. Select the target language in the locale dropdown
  2. Click "Translate all" in the toolbar
  3. Confirm the action in the dialog
  4. All text fields are translated simultaneously

Bulk translate confirmation dialog

Page with all fields translated

Page before translation — translate buttons visible on each field

📊 DeepL Usage Statistics

The bundle provides a settings view accessible under Settings > DeepL Translator, showing your DeepL API usage:

  • Account type badge (Free or Pro)
  • Billing period dates (Pro accounts only)
  • Characters used vs. plan limit with a visual progress bar (green / yellow / red)
  • Refresh button and direct link to your DeepL dashboard

DeepL usage statistics page

Permissions

Access to the statistics page is controlled by the Sulu permission system. A "translator" entry appears under Settings in the role permissions. Enable the View permission to grant access.

Translator permission in role settings

📋 Supported Field Types

Sulu Field Type Support Notes
text_line Single-line text input
text_area Multi-line text area
text_editor Rich text

🔌 REST API Endpoints

The bundle exposes two admin API endpoints:

Method Endpoint Description
POST /admin/api/translator/translate Translate text content
GET /admin/api/translator/usage Get DeepL API usage stats

POST /admin/api/translator/translate

Request body:

{
    "text": "Bonjour le monde",
    "target": "en",
    "source": "fr",
    "html": false
}
Field Type Required Description
text string Yes Text content to translate
target string Yes Target Sulu locale code
source string No Source language (auto-detected if omitted)
html boolean No Set to true for rich text fields to preserve HTML markup

Response:

{
    "translation": "Hello world"
}

GET /admin/api/translator/usage

Response:

{
    "character_count": 42500,
    "character_limit": 500000,
    "account_type": "free",
    "start_time": null,
    "end_time": null
}

Note: start_time and end_time are only returned for Pro accounts. Free accounts will receive null for these fields.

🐛 Bug and Idea

See the open issues for a list of proposed features (and known issues).

💰 Support me

You can buy me a coffee to support me this plugin is 100% free.

Buy me a coffee

👨‍💻 Contact

x.com Linkedin

📘  License

This bundle is under the MIT License.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 0
  • Forks: 0
  • 开发语言: JavaScript

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-02-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固