-import * as jsToXliff12 from 'xliff/jsToXliff12'
-import { writeFile } from 'fs'
+import { writeJSON } from 'fs-extra'
import { join } from 'path'
-import { buildLanguages, VIDEO_CATEGORIES, VIDEO_LICENCES, VIDEO_PRIVACIES } from '../../server/initializers/constants'
-import { values } from 'lodash'
+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 { 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',
'Speed': 'Speed',
+ 'Subtitles/CC': 'Subtitles/CC',
'peers': 'peers',
+ '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'
-}
-const playerTranslations = {
- target: join(__dirname, '../../../client/src/locale/source/player_en_US.xml'),
- data: Object.assign({}, videojs, playerKeys)
+ 'Copy embed code': 'Copy embed code',
+ 'Copy magnet URI': 'Copy magnet URI',
+ 'Total downloaded: ': 'Total downloaded: ',
+ '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.',
+ '{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))
- .forEach(v => serverKeys[v] = v)
-
-// ISO 639 keys
-const languages = buildLanguages()
-Object.keys(languages).forEach(k => serverKeys[languages[k]] = languages[k])
+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.',
+ 'Sorry',
+ '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 })
// 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
-}
-
-saveToXliffFile(playerTranslations, err => {
- if (err) return handleError(err)
+// ISO 639 keys
+const languageKeys: any = {}
+const languages = buildLanguages()
+Object.keys(languages).forEach(k => { languageKeys[languages[k]] = languages[k] })
- saveToXliffFile(serverTranslations, err => {
- if (err) return handleError(err)
+Object.assign(serverKeys, languageKeys)
- 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)
-}
\ No newline at end of file
+ const newTranslatedServer = Object.assign({}, serverKeys, translatedServer)
+ await writeJSON(serverJsonPath, newTranslatedServer, { spaces: 4 })
+ }
+}