X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=scripts%2Fi18n%2Fcreate-custom-files.ts;h=72136614c43da47e19f3008f69d5e6a368f2623d;hb=8777a98e3abb21eb641b37663b2d86e2a5b70cbb;hp=78a51d1e657ac17bd4a9e55c2168e7cc97b0d170;hpb=56674bb9f81775ff85115e7daa7d9be0db95c001;p=github%2FChocobozzz%2FPeerTube.git diff --git a/scripts/i18n/create-custom-files.ts b/scripts/i18n/create-custom-files.ts index 78a51d1e6..72136614c 100755 --- a/scripts/i18n/create-custom-files.ts +++ b/scripts/i18n/create-custom-files.ts @@ -1,9 +1,13 @@ -import { registerTSPaths } from '../../server/helpers/register-ts-paths' import { writeJSON } from 'fs-extra' import { join } from 'path' +import { root, USER_ROLE_LABELS } from '@shared/core-utils' import { + ABUSE_STATES, buildLanguages, + RUNNER_JOB_STATES, + USER_REGISTRATION_STATES, VIDEO_CATEGORIES, + VIDEO_CHANNEL_SYNC_STATE, VIDEO_IMPORT_STATES, VIDEO_LICENCES, VIDEO_PLAYLIST_PRIVACIES, @@ -11,11 +15,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 +33,60 @@ 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', + 'Previous video': 'Previous video', + 'Video page (new window)': 'Video page (new window)', + 'Next video': 'Next video' } 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(Object.values(USER_ROLE_LABELS)) + .concat(Object.values(VIDEO_CHANNEL_SYNC_STATE)) + .concat(Object.values(ABUSE_STATES)) + .concat(Object.values(USER_REGISTRATION_STATES)) + .concat(Object.values(RUNNER_JOB_STATES)) .concat([ 'This video does not exist.', 'We cannot fetch the video. Please try again later.', @@ -59,7 +102,6 @@ values(VIDEO_CATEGORIES) // More keys Object.assign(serverKeys, { - Misc: 'Misc', Unknown: 'Unknown' }) @@ -70,10 +112,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 }) + } +}