wernerkrauss / silverstripe-fluent-export-import
File export and import for SilverStripe Fluent
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 0
Open Issues: 1
Type:silverstripe-vendormodule
Requires
- php: ^8.2
- ext-zip: *
- lekoala/silverstripe-cms-actions: ^1.7.5
- lekoala/silverstripe-pure-modal: ^1.2.1
- openai-php/client: ^0.10
- silverstripe/framework: ^5.2
- tractorcow/silverstripe-fluent: ^7
Requires (Dev)
This package is auto-updated.
Last update: 2025-01-09 14:43:19 UTC
README
An extension for silvertripe/fluent
- export and import translations with yml files
- automatically translate content using ChatGPT.
Installation
composer require wernerkrauss/silverstripe-fluent-export-import
Important notice
I take no warranty for any data loss. Please backup your database before importing translations.
There is only a check if the yml file has the same locale as you plan to import. Using the import funcitonality will overwrite the related content in the database.
Please validate the yml files before importing them. Take care to escape apostrophs.
Import / Export
Export
Run dev/tasks/fluent-export
to export all translations as a zip of yml files.
You can also go to the LocaleAdmin and click on the export button.
Now you can translate the content and import it again.
Import
Translations are imported in LocaleAdmin. Hit the import button and select the zip or yml file you want to import.
Configuration
You can configure fields you don't want to export, e.g. SiteTree's URLSegment:
SilverStripe\CMS\Model\SiteTree: translate_ignore: - URLSegment
Automatic Translation
You can use the ChatGPT API to translate your content. To do so, you need to set the API key in your .env file:
CHATGPT_API_KEY=your-api-key
Next add extension to all classes you want to translate:
# SiteTree has already fluent applied SilverStripe\CMS\Model\SiteTree: extensions: autotranslate: Netwerkstatt\FluentExIm\Extension\AutoTranslate My\Namespace\Model\Foo: extensions: fluent: TractorCow\Fluent\Extension\FluentExtension autotranslate: Netwerkstatt\FluentExIm\Extension\AutoTranslat # if you have configured translations, make sure to add IsAutoTranslated and LastTranslation manually translate: - IsAutoTranslated - LastTranslation
The AutoTranslate
extension adds a flag IsAutoTranslated
to the class and a field LastTranslation
to each locale. It's meant to be controlled by an editor, if the translation is correct.
⚠️ Be aware, that some extensions of other modules might add translated
config to a class. Then you have to add IsAutoTranslated
and LastTranslation
to the translated
config as well.
Configuring ChatGPT
You can configure the ChatGPT API in your config.yml:
Netwerkstatt\FluentExIm\Translator\ChatGPTTranslator: gpt_model: gpt-4o-mini # %s will be replaced with the target locale gpt_command: 'You are a professional translator. Translate the following text to %s language. Please keep the json format intact.'
If you need to configure the gpt_command more dynamically, you can use the following code in an Extension to ChatGPTTranslator
:
public function updateGptCommand(&$command, $locale) { $command = 'You are a professional translator. Translate the following text to ' . $locale . ' language. Please keep the json format intact.'; }
fluent-ai-autotranslate task
When everything is configured properly you can run the task dev/tasks/fluent-ai-autotranslate do_publish=1
to translate all content to the desired locale.
If IsAutoTranslated of LastTranslation is missing in localised fields, the task will throw a RuntimeException.
Notice: the task can only publish translated content, if you use FluentVersionedExtension
instead of FluentExtension
on the versioned DataObjects.
Parameters:
do_publish
(required): If set to 1, the task will publish the translated content.force_translation
(optional): If set to 1, the task will translate all content that is untranslated or marked as previoulsy auto translated, even if it was already translated.
Todo
File Import/Export
-
Export translations to YML -
Import translations from YML -
Import translations from a zip containing yml files - other file adapters for import/export like json or xliff
-
better UI, e.g. in LocaleAdmin - use AI on export to translate content; export original and translated content
AI Translation
-
documentation how to ask ChatGPT to translate in a correct way - implement other translation services like DeepL
Thanks to
Thanks to Nobrainer and Adiwidjaja Teamworks for sponsoring this module ❤️.
A special thank you to Lekoala for the support with his CMS-Actions and PureModal modules.
Thanks to TractorCow and all contributors for the great fluent module. And thanks to the folks at Silverstripe for their great work.
Need Help?
If you need some help with your Silverstripe project, feel free to contact me ✉️.
See you at next StripeCon 👋