scratch-l10n/scripts/build-data.js
chrisgarrity 73f9b8619e Refactor data exported for GUI
Create editor folder for all the editor components:
* blocks - from scratch-blocks
* extensions - from scratch-vm
* interface - from scratch-gui
* paint-editor - from scratch-paint.

Update the transifex config, initilaize with the english sources.

Export a combined editor-msgs.js in addition to individual files.

Renamed paint to paint-editor to match the name in transifex.
2018-05-21 09:42:53 -04:00

112 lines
3.2 KiB
JavaScript
Executable file

#!/usr/bin/env node
/*
Generates locales/<component>-msgs.js for each component (gui, etc) from the
current translation files for each language for that component
Translation files are expected to be in Chrome i18n json format:
'''
{
"message.id": {
"message": "The translated text",
"description": "Tips for translators"
},
...
}
'''
They are named by locale, for example: 'fr.json' or 'zh-cn.json'
Converts the collection of translation files to a single set of messages.
Example output:
'''
{
"en": {
"action.addBackdrop": "Add Backdrop",
"action.addCostume": "Add Costume",
"action.recordSound": "Record Sound",
"action.addSound": "Add Sound"
},
"fr": {
"action.addSound": "Ajouter Son",
"action.addCostume": "Ajouter Costume",
"action.addBackdrop": "Ajouter Arrière-plan",
"action.recordSound": "Enregistrement du Son"
}
}
'''
NOTE: blocks messages are plain key-value JSON files
Missing locales are ignored, react-intl will use the default messages for them.
*/
import * as fs from 'fs';
import * as path from 'path';
import {sync as mkdirpSync} from 'mkdirp';
import defaultsDeep from 'lodash.defaultsdeep';
import locales from '../src/supported-locales.js';
const MSGS_DIR = './locales/';
mkdirpSync(MSGS_DIR);
let missingLocales = [];
// generate messages for gui components - files are Chrome i18n format json
let components = ['interface', 'extensions', 'paint-editor'];
let editorMsgs = {};
components.forEach((component) => {
let messages = Object.keys(locales).reduce((collection, lang) => {
let langMessages = {};
try {
let langData = JSON.parse(
fs.readFileSync(path.resolve('editor', component, lang + '.json'), 'utf8')
);
Object.keys(langData).forEach((id) => {
langMessages[id] = langData[id].message;
});
collection[lang] = langMessages;
} catch (e) {
missingLocales.push(lang);
}
return collection;
}, {});
let data =
'// GENERATED FILE:\n' +
'export default ' +
JSON.stringify(messages, null, 2) +
';\n';
fs.writeFileSync(MSGS_DIR + component + '-msgs.js', data);
defaultsDeep(editorMsgs, messages);
if (missingLocales.length > 0) {
process.stdout.write('missing locales: ' + missingLocales.toString());
process.exit(1);
}
});
// generate the blocks messages: files are plain key-value JSON
let blocksMessages = Object.keys(locales).reduce((collection, lang) => {
try {
let langData = JSON.parse(
fs.readFileSync(path.resolve('editor', 'blocks', lang + '.json'), 'utf8')
);
collection[lang] = langData;
} catch (e) {
missingLocales.push(lang);
}
return collection;
}, {});
let blockData =
'// GENERATED FILE:\n' +
'export default ' +
JSON.stringify(blocksMessages, null, 2) +
';\n';
fs.writeFileSync(MSGS_DIR + 'blocks-msgs.js', blockData);
defaultsDeep(editorMsgs, blocksMessages);
// generate combined editor-msgs file
let editorData =
'// GENERATED FILE:\n' +
'export default ' +
JSON.stringify(editorMsgs, null, 2) +
';\n';
fs.writeFileSync(MSGS_DIR + 'editor-msgs.js', editorData);