X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=scripts%2Fi18n%2Fcreate-custom-files.ts;h=e52909c433987dacc2a9189c5d48e71d1b520190;hb=ba2684ceddf9b76312635b9cddc6bf6975ce436a;hp=664207e1c91a3805dfb180ee537ca903c8c9050d;hpb=88108880bbdba473cfe36ecbebc1c3c4f972e102;p=github%2FChocobozzz%2FPeerTube.git diff --git a/scripts/i18n/create-custom-files.ts b/scripts/i18n/create-custom-files.ts index 664207e1c..e52909c43 100755 --- a/scripts/i18n/create-custom-files.ts +++ b/scripts/i18n/create-custom-files.ts @@ -1,22 +1,20 @@ -import * as jsToXliff12 from 'xliff/jsToXliff12' -import { writeFile } from 'fs-extra' +import { writeJSON } from 'fs-extra' +import { values } from 'lodash' import { join } from 'path' +import { root } from '@shared/core-utils' import { buildLanguages, VIDEO_CATEGORIES, VIDEO_IMPORT_STATES, VIDEO_LICENCES, + VIDEO_PLAYLIST_PRIVACIES, + VIDEO_PLAYLIST_TYPES, VIDEO_PRIVACIES, VIDEO_STATES } from '../../server/initializers/constants' -import { values } from 'lodash' +import { I18N_LOCALES } from '../../shared/core-utils/i18n' -type TranslationType = { - target: string - data: { [id: string]: string } -} - -const videojs = require(join(__dirname, '../../../client/src/locale/source/videojs_en_US.json')) +const videojs = require(join(root(), 'client', 'src', 'locale', 'videojs.en-US.json')) const playerKeys = { 'Quality': 'Quality', 'Auto': 'Auto', @@ -26,17 +24,44 @@ const playerKeys = { 'peer': 'peer', 'Go to the video page': 'Go to the video page', 'Settings': 'Settings', - 'Uses P2P, others may know you are watching this video.': 'Uses P2P, others may know you are watching this video.', + 'Watching this video may reveal your IP address to others.': 'Watching this video may reveal your IP address to others.', 'Copy the video URL': 'Copy the video URL', 'Copy the video URL at the current time': 'Copy the video URL at the current time', 'Copy embed code': 'Copy embed code', + 'Copy magnet URI': 'Copy magnet URI', 'Total downloaded: ': 'Total downloaded: ', - 'Total uploaded: ': 'Total uploaded: ' -} -const playerTranslations = { - target: join(__dirname, '../../../client/src/locale/source/player_en_US.xml'), - data: Object.assign({}, videojs, playerKeys) + 'Total uploaded: ': 'Total uploaded: ', + 'From servers: ': 'From servers: ', + 'From peers: ': 'From peers: ', + 'Normal mode': 'Normal mode', + 'Stats for nerds': 'Stats for nerds', + 'Theater mode': 'Theater mode', + 'Video UUID': 'Video UUID', + 'Viewport / Frames': 'Viewport / Frames', + 'Resolution': 'Resolution', + 'Volume': 'Volume', + 'Codecs': 'Codecs', + 'Color': 'Color', + 'Connection Speed': 'Connection Speed', + 'Network Activity': 'Network Activity', + 'Total Transfered': 'Total Transfered', + 'Download Breakdown': 'Download Breakdown', + 'Buffer Progress': 'Buffer Progress', + 'Buffer State': 'Buffer State', + 'Live Latency': 'Live Latency', + 'P2P': 'P2P', + '{1} seconds': '{1} seconds', + 'enabled': 'enabled', + 'Playlist: {1}': 'Playlist: {1}', + 'disabled': 'disabled', + ' off': ' off', + 'Player mode': 'Player mode', + 'Play in loop': 'Play in loop', + 'This live has not started yet.': 'This live has not started yet.', + 'This live has ended.': 'This live has ended.', + 'The video failed to play, will try to fast forward.': 'The video failed to play, will try to fast forward.' } +Object.assign(playerKeys, videojs) // Server keys const serverKeys: any = {} @@ -45,71 +70,56 @@ values(VIDEO_CATEGORIES) .concat(values(VIDEO_PRIVACIES)) .concat(values(VIDEO_STATES)) .concat(values(VIDEO_IMPORT_STATES)) + .concat(values(VIDEO_PLAYLIST_PRIVACIES)) + .concat(values(VIDEO_PLAYLIST_TYPES)) .concat([ 'This video does not exist.', 'We cannot fetch the video. Please try again later.', 'Sorry', - 'This video is not available because the remote instance is not responding.' + 'This video is not available because the remote instance is not responding.', + 'This playlist does not exist', + 'We cannot fetch the playlist. Please try again later.', + 'Playlist: {1}', + 'By {1}', + 'Unavailable video' ]) - .forEach(v => serverKeys[v] = v) + .forEach(v => { serverKeys[v] = v }) // More keys Object.assign(serverKeys, { - 'Misc': 'Misc', - 'Unknown': 'Unknown' + Misc: 'Misc', + Unknown: 'Unknown' }) -const serverTranslations = { - target: join(__dirname, '../../../client/src/locale/source/server_en_US.xml'), - data: serverKeys -} - // ISO 639 keys const languageKeys: any = {} const languages = buildLanguages() -Object.keys(languages).forEach(k => languageKeys[languages[k]] = languages[k]) - -const iso639Translations = { - target: join(__dirname, '../../../client/src/locale/source/iso639_en_US.xml'), - data: languageKeys -} +Object.keys(languages).forEach(k => { languageKeys[languages[k]] = languages[k] }) -saveToXliffFile(playerTranslations, err => { - if (err) return handleError(err) +Object.assign(serverKeys, languageKeys) - saveToXliffFile(serverTranslations, err => { - if (err) return handleError(err) - - saveToXliffFile(iso639Translations, err => { - if (err) return handleError(err) - - process.exit(0) - }) - }) +writeAll().catch(err => { + console.error(err) + process.exit(-1) }) -// Then, the server strings +async function writeAll () { + const localePath = join(root(), 'client', 'src', 'locale') -function saveToXliffFile (jsonTranslations: TranslationType, cb: Function) { - const obj = { - resources: { - namespace1: {} - } - } - Object.keys(jsonTranslations.data).forEach(k => obj.resources.namespace1[ k ] = { source: jsonTranslations.data[ k ] }) + await writeJSON(join(localePath, 'player.en-US.json'), playerKeys, { spaces: 4 }) + await writeJSON(join(localePath, 'server.en-US.json'), serverKeys, { spaces: 4 }) - jsToXliff12(obj, (err, res) => { - if (err) return cb(err) + for (const key of Object.keys(I18N_LOCALES)) { + const playerJsonPath = join(localePath, `player.${key}.json`) + const translatedPlayer = require(playerJsonPath) - writeFile(jsonTranslations.target, res, err => { - if (err) return cb(err) + const newTranslatedPlayer = Object.assign({}, playerKeys, translatedPlayer) + await writeJSON(playerJsonPath, newTranslatedPlayer, { spaces: 4 }) - return cb(null) - }) - }) -} + const serverJsonPath = join(localePath, `server.${key}.json`) + const translatedServer = require(serverJsonPath) -function handleError (err: any) { - console.error(err) - process.exit(-1) + const newTranslatedServer = Object.assign({}, serverKeys, translatedServer) + await writeJSON(serverJsonPath, newTranslatedServer, { spaces: 4 }) + } }