X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;ds=sidebyside;f=scripts%2Fi18n%2Fcreate-custom-files.ts;h=3b504595462821909b452c0b046ca71ad17442d4;hb=458685e0d039a0ad3fa4f26d99746f7d6d0b40e9;hp=89a967b148b194f96037af449f45b91c7aaceffb;hpb=4572c3d0d92f5b1b79b34dbe2c7b6557a8a5b7e4;p=github%2FChocobozzz%2FPeerTube.git diff --git a/scripts/i18n/create-custom-files.ts b/scripts/i18n/create-custom-files.ts index 89a967b14..3b5045954 100755 --- a/scripts/i18n/create-custom-files.ts +++ b/scripts/i18n/create-custom-files.ts @@ -1,6 +1,6 @@ -import { registerTSPaths } from '../../server/helpers/register-ts-paths' import { writeJSON } from 'fs-extra' import { join } from 'path' +import { root } from '@shared/core-utils' import { buildLanguages, VIDEO_CATEGORIES, @@ -11,11 +11,9 @@ import { VIDEO_PRIVACIES, VIDEO_STATES } from '../../server/initializers/constants' -import { values } from 'lodash' +import { I18N_LOCALES } from '../../shared/core-utils/i18n' -registerTSPaths() - -const videojs = require(join(__dirname, '../../../client/src/locale/videojs.en-US.json')) +const videojs = require(join(root(), 'client', 'src', 'locale', 'videojs.en-US.json')) const playerKeys = { 'Quality': 'Quality', 'Auto': 'Auto', @@ -31,19 +29,52 @@ const playerKeys = { 'Copy embed code': 'Copy embed code', 'Copy magnet URI': 'Copy magnet URI', 'Total downloaded: ': 'Total downloaded: ', - 'Total uploaded: ': 'Total uploaded: ' + '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', + 'Go back to the live': 'Go back to the live', + '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.', + '{1} / {2} dropped of {3}': '{1} / {2} dropped of {3}', + ' (muted)': ' (muted)', + '{1} from servers · {2} from peers': '{1} from servers · {2} from peers' } Object.assign(playerKeys, videojs) // Server keys const serverKeys: any = {} -values(VIDEO_CATEGORIES) - .concat(values(VIDEO_LICENCES)) - .concat(values(VIDEO_PRIVACIES)) - .concat(values(VIDEO_STATES)) - .concat(values(VIDEO_IMPORT_STATES)) - .concat(values(VIDEO_PLAYLIST_PRIVACIES)) - .concat(values(VIDEO_PLAYLIST_TYPES)) +Object.values(VIDEO_CATEGORIES) + .concat(Object.values(VIDEO_LICENCES)) + .concat(Object.values(VIDEO_PRIVACIES)) + .concat(Object.values(VIDEO_STATES)) + .concat(Object.values(VIDEO_IMPORT_STATES)) + .concat(Object.values(VIDEO_PLAYLIST_PRIVACIES)) + .concat(Object.values(VIDEO_PLAYLIST_TYPES)) .concat([ 'This video does not exist.', 'We cannot fetch the video. Please try again later.', @@ -52,7 +83,8 @@ values(VIDEO_CATEGORIES) 'This playlist does not exist', 'We cannot fetch the playlist. Please try again later.', 'Playlist: {1}', - 'By {1}' + 'By {1}', + 'Unavailable video' ]) .forEach(v => { serverKeys[v] = v }) @@ -69,10 +101,28 @@ Object.keys(languages).forEach(k => { languageKeys[languages[k]] = languages[k] Object.assign(serverKeys, languageKeys) -Promise.all([ - writeJSON(join(__dirname, '../../../client/src/locale/player.en-US.json'), playerKeys), - writeJSON(join(__dirname, '../../../client/src/locale/server.en-US.json'), serverKeys) -]).catch(err => { +writeAll().catch(err => { console.error(err) process.exit(-1) }) + +async function writeAll () { + const localePath = join(root(), 'client', 'src', 'locale') + + await writeJSON(join(localePath, 'player.en-US.json'), playerKeys, { spaces: 4 }) + await writeJSON(join(localePath, 'server.en-US.json'), serverKeys, { spaces: 4 }) + + for (const key of Object.keys(I18N_LOCALES)) { + const playerJsonPath = join(localePath, `player.${key}.json`) + const translatedPlayer = require(playerJsonPath) + + const newTranslatedPlayer = Object.assign({}, playerKeys, translatedPlayer) + await writeJSON(playerJsonPath, newTranslatedPlayer, { spaces: 4 }) + + const serverJsonPath = join(localePath, `server.${key}.json`) + const translatedServer = require(serverJsonPath) + + const newTranslatedServer = Object.assign({}, serverKeys, translatedServer) + await writeJSON(serverJsonPath, newTranslatedServer, { spaces: 4 }) + } +}