You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
cryptpad/customize.dist/translations
ansuz e2600e4b36 display a loading screen while users are changing their passwords 7 years ago
..
README.md Stop using presentSuccess because it is hidden behind the modal in slide 7 years ago
messages.de.js Merge pull request #249 from xwiki-labs/de-translation-pl 7 years ago
messages.el.js Automatic account deletion 7 years ago
messages.es.js Automatic account deletion 7 years ago
messages.fr.js Update French translation 7 years ago
messages.js display a loading screen while users are changing their passwords 7 years ago
messages.pl.js Stop using presentSuccess because it is hidden behind the modal in slide 7 years ago
messages.pt-br.js Automatic account deletion 7 years ago
messages.ro.js Automatic account deletion 7 years ago
messages.zh.js Automatic account deletion 7 years ago

README.md

Adding Translations

To illustrate the process of translating, this guide will make an english-pirate translation of Cryptpad. We'll assume that you have a work locally-installed, properly functioning installation of Cryptpad. If you don't have Cryptpad installed locally, start by following the steps in the main readme.

Getting started

Once everything is working, copy the default (English) source file (/customize.dist/translations/messages.js) to a file named according to your language's ISO 639-1 Code, like /customize.dist/translations/messages.fr.js. There is no ISO 639-1 language code for English-pirate, so we'll just call it messages.pirate.js.

cd /customize.dist/translations/
cp messages.js messages.pirate.js

Including your translation

To include your translation in the list, you'll need to add it to /customize.dist/messages.js. There are comments indicating what to modify in three places:

(function () {
var LS_LANG = "CRYPTPAD_LANG";

var getStoredLanguage = function () { return localStorage.getItem(LS_LANG); };
var getBrowserLanguage = function () { return navigator.language || navigator.userLanguage; };
var getLanguage = function () { return getStoredLanguage() || getBrowserLanguage(); };
var language = getLanguage();

// add your module to this map so it gets used
// please use the translated name of your language ("Français" and not "French"
var map = {
    'fr': 'Français',
    'es': 'Español',
    'pl': 'Polski',
    'de': 'Deutsch',
    'pt-br': 'Português do Brasil'
};

We need to modify that map to include our translation:

(function () {
var LS_LANG = "CRYPTPAD_LANG";

var getStoredLanguage = function () { return localStorage.getItem(LS_LANG); };
var getBrowserLanguage = function () { return navigator.language || navigator.userLanguage; };
var getLanguage = function () { return getStoredLanguage() || getBrowserLanguage(); };
var language = getLanguage();

// add your module to this map so it gets used
// please use the translated name of your language ("Français" and not "French"
var map = {
    'fr': 'Français',
    'es': 'Español',
    'pl': 'Polski',
    'de': 'Deutsch',
    'pt-br': 'Português do Brasil'
    'pirate': 'English Pirate', // add our module to the map of languages
};

Just add your module in a similar fashion to the existing translations, save your changes, and close /customize.dist/messages.js. That's all!

Actually translating content

Now we can go back to our file, /customize.dist/translations/messages.pirate.js and start to add our Pirate-language customizations.

Open the translation file you created in /customize.dist/translations/. You should see something like:

define(function () {
    var out = {};

    out.main_title = "Cryptpad: Zero Knowledge, Collaborative Real Time Editing";

Now you just need to work through this file, updating the strings like so:

define(function () {
    var out = {};

    out.main_title = "Cryptpad: Knowledge lost at sea while ye scribble with yer mateys";

It's important that you modify just the string, and not the variable name which is used to access its content. For instance, changing main_title to mainTitle would make the translated string inaccessible to the rest of the codebase.

If a key is not found in your translation, the default English version of that key will be used. This is to make sure that buttons and other interface elements are not empty, but it's obviously not ideal.

Verifying Your Translations

It's advisable to save your translation file frequently, and reload Cryptpad in your browser to check that there are no errors in your translation file. If there are any errors in your code, the file will fail to parse, and the page will no load correctly.

Checking frequently will make it easier to know which change caused the error.

Additionally, we advise using the apps and visiting the various pages, to make sure that your translations make sense in context.

When you're happy with your translation file, you can visit http://localhost:3000/assert/translations/ to view Cryptpad's tests. These tests will check to make sure that your translation has an entry for every entry in the default English translation.

Getting Help

If you have any issues, reach out via any of the methods listed in the readme under Contacting Us. We're happy to help.

Deleting a translation

When a key is nolonger used (such as presentSuccess) you can delete it using this bash one-liner.

( export KEY=presentSuccess && grep -nr "$KEY" ./customize.dist/translations/ | sed 's/:.*$//' | while read x; do sed -i -e "/out\.$KEY =/d" $x; done )