はじまりの大地
このコミットが含まれているのは:
実行可能ファイル
+154
@@ -0,0 +1,154 @@
|
||||
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 })
|
||||
}
|
||||
}
|
||||
実行可能ファイル
+15
@@ -0,0 +1,15 @@
|
||||
#!/bin/sh
|
||||
|
||||
set -eu
|
||||
|
||||
git fetch weblate && git merge weblate/develop
|
||||
|
||||
cd client
|
||||
npm run ng -- extract-i18n --out-file src/locale/angular.xlf
|
||||
|
||||
# Merge new translations in other language files
|
||||
node ./node_modules/.bin/xliffmerge -p ./.xliffmerge.json "ar" "is" "hr" "ca-ES" "gl-ES" "cs-CZ" "da-DK" "de-DE" "el-GR" "en-GB" "en-US" "eo" "es-ES" "eu-ES" "fa-IR" "fi-FI" "fr-FR" "gd" "gl-ES" "hu-HU" "it-IT" "ja-JP" "jbo" "kab" "ko-KR" "lt-LT" "nb-NO" "nl-NL" "oc" "pl-PL" "pt-BR" "pt-PT" "ru-RU" "sk-SK" "sl-SI" "sv-SE" "ta" "th-TH" "tr-TR" "uk-UA" "vi-VN" "zh-Hans-CN" "zh-Hant-TW" "nn" "nb-NO" "tok"
|
||||
|
||||
# Add our strings too
|
||||
cd ../
|
||||
npm run i18n:create-custom-files
|
||||
新しい課題から参照
ユーザをブロックする