digitalpulsebe / craft-database-translations
Manage Craft i18n translations and store in database
Installs: 1 396
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 1
Open Issues: 1
Type:craft-plugin
pkg:composer/digitalpulsebe/craft-database-translations
Requires
- craftcms/cms: ^5.0.0-alpha.1
- dev-master
- 3.3.10
- 3.3.9
- 3.3.8
- 3.3.7
- 3.3.6
- 3.3.5
- 3.3.4
- 3.3.3
- 3.3.2
- 3.3.1
- 3.3.0
- 3.2.4
- 3.2.3
- 3.2.2
- 3.2.1
- 3.2.0
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.1
- 3.0.0
- 2.7.9
- 2.7.8
- 2.7.7
- 2.7.6
- 2.7.5
- 2.7.4
- 2.7.3
- 2.7.2
- 2.7.1
- 2.7.0
- 2.6.5
- 2.6.4
- 2.6.3
- 2.6.2
- 2.6.1
- 2.6.0
- 2.5.3
- 2.5.2
- 2.5.1
- 2.5.0
- 2.4.0
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.2
- 2.0.1
- 2.0.0
- 1.2.0
- 1.1.3
- 1.1.2
- 1.1.1
- 1.1.0
- 1.0.2
- 1.0.1
- 1.0.0
- dev-craft-4
- dev-craft-4-develop
- dev-develop
- dev-craft-3
- dev-craft-3-develop
This package is auto-updated.
Last update: 2025-10-19 08:42:34 UTC
README
Manage Craft i18n translations and store in database
Requirements
This plugin requires Craft CMS 3.7 or later.
Installation
To install the plugin, follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require digitalpulsebe/craft-database-translations
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for Database Translations.
Configuring Database Translations
Configure options in the Craft control panel or create a file in config/database-translations.php as a copy of config.php.
Configure the translation categories
Only the categories defined in the settings will be translated.
Map languages
Do you need to use the same translated values for different languages (for example different regions nl-BE and nl-NL)? You can map one language to another.
This might also be useful to provide translations for admin user in the control panel.
Trim spaces
Trim spaces at begin or ending of values when they are saved.
Add missing translations
When a new unknown translation is used while rendering templates, an event is triggered. Handling this event is optional. A new empty translation row will be added for the missing message.
Copy Entry bulk action
Enable this feature
Importing translations
Apart from the automatic missing translations' event, there are four ways of adding message rows in the database:
-
Create one manually
Just enter the new message key and category to add an empty row
-
Parse twig templates
Twig files are processed to find usage of the |t filter. The found results are listed in a review-step, select the rows you want to add to the database.
-
Import CSV files
Import CSV files. Map the columns.
The found results are listed in a review-step, select the rows you want to add to the database.
-
Parse php translation files
The native translation files in ./translations folder can be mapped to database rows. The found results are listed in a review-step, select the rows you want to add to the database. You can even import files from plugins in the vendor folder.
Exporting
- Export all the rows using the export tab
- Or, in the overview table, select the rows and languages to export
- as csv file
- as a content migration file
Migration file export
The advantage of exporting to a migration file is that your content can be pushed to git and then the server when deploying. The migration file adds the rows to your database when craft up
or craft migrate/all
is executed.
Manage translations
Copy entries in bulk action
To enable this functionality both enable this in the settings and set the permission for the user ("Copy content bulk action").
You can now select Entries in the index table, and select the bulk action. The content will be copied over to the other site in a queue job.