155 lines
5.5 KiB
TypeScript
Executable File
155 lines
5.5 KiB
TypeScript
Executable File
import { readJsonSync, writeJSON } from 'fs-extra/esm'
|
|
import { join } from 'path'
|
|
import { I18N_LOCALES, USER_ROLE_LABELS } from '@peertube/peertube-core-utils'
|
|
import { root } from '@peertube/peertube-node-utils'
|
|
import {
|
|
ABUSE_STATES,
|
|
buildLanguages,
|
|
RUNNER_JOB_STATES,
|
|
USER_EXPORT_STATES,
|
|
USER_REGISTRATION_STATES,
|
|
VIDEO_CATEGORIES,
|
|
VIDEO_CHANNEL_SYNC_STATE,
|
|
VIDEO_IMPORT_STATES,
|
|
VIDEO_LICENCES,
|
|
VIDEO_PLAYLIST_PRIVACIES,
|
|
VIDEO_PLAYLIST_TYPES,
|
|
VIDEO_PRIVACIES,
|
|
USER_IMPORT_STATES,
|
|
VIDEO_STATES
|
|
} from '@peertube/peertube-server/core/initializers/constants.js'
|
|
|
|
const videojs = readJsonSync(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',
|
|
'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: ',
|
|
'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',
|
|
'This video is password protected': 'This video is password protected',
|
|
'You need a password to watch this video.': 'You need a password to watch this video.',
|
|
'Incorrect password, please enter a correct password': 'Incorrect password, please enter a correct password',
|
|
'Cancel': 'Cancel',
|
|
'Up Next': 'Up Next',
|
|
'Autoplay is suspended': 'Autoplay is suspended',
|
|
'{1} (from edge: {2})': '{1} (from edge: {2})',
|
|
'Disable subtitles': 'Disable subtitles',
|
|
'Enable {1} subtitle': 'Enable {1} subtitle',
|
|
'{1} (auto-generated)': '{1} (auto-generated)',
|
|
'Go back': 'Go back'
|
|
}
|
|
Object.assign(playerKeys, videojs)
|
|
|
|
// Server keys
|
|
const serverKeys: any = {}
|
|
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(Object.values(USER_EXPORT_STATES))
|
|
.concat(Object.values(USER_IMPORT_STATES))
|
|
.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, {
|
|
Unknown: 'Unknown'
|
|
})
|
|
|
|
// ISO 639 keys
|
|
const languageKeys: any = {}
|
|
const languages = buildLanguages()
|
|
Object.keys(languages).forEach(k => { languageKeys[languages[k]] = languages[k] })
|
|
|
|
Object.assign(serverKeys, languageKeys)
|
|
|
|
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 = readJsonSync(playerJsonPath)
|
|
|
|
const newTranslatedPlayer = Object.assign({}, playerKeys, translatedPlayer)
|
|
await writeJSON(playerJsonPath, newTranslatedPlayer, { spaces: 4 })
|
|
|
|
const serverJsonPath = join(localePath, `server.${key}.json`)
|
|
const translatedServer = readJsonSync(serverJsonPath)
|
|
|
|
const newTranslatedServer = Object.assign({}, serverKeys, translatedServer)
|
|
await writeJSON(serverJsonPath, newTranslatedServer, { spaces: 4 })
|
|
}
|
|
}
|