aboutsummaryrefslogtreecommitdiffhomepage
path: root/scripts/i18n/create-custom-files.ts
blob: 40c4208253db678c1029a6d57d803625db78fbf8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import * as jsToXliff12 from 'xliff/jsToXliff12'
import { writeFile } from 'fs-extra'
import { join } from 'path'
import {
  buildLanguages,
  VIDEO_CATEGORIES,
  VIDEO_IMPORT_STATES,
  VIDEO_LICENCES,
  VIDEO_PRIVACIES,
  VIDEO_STATES
} from '../../server/initializers/constants'
import { values } from 'lodash'

type TranslationType = {
  target: string
  data: { [id: string]: string }
}

const videojs = require(join(__dirname, '../../../client/src/locale/source/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.',
  '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: '
}
const playerTranslations = {
  target: join(__dirname, '../../../client/src/locale/source/player_en_US.xml'),
  data: Object.assign({}, videojs, playerKeys)
}

// 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([
    '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.'
  ])
  .forEach(v => serverKeys[v] = v)

// More keys
Object.assign(serverKeys, {
  'Misc': 'Misc',
  'Unknown': 'Unknown'
})

const serverTranslations = {
  target: join(__dirname, '../../../client/src/locale/source/server_en_US.xml'),
  data: serverKeys
}

// ISO 639 keys
const languageKeys: any = {}
const languages = buildLanguages()
Object.keys(languages).forEach(k => languageKeys[languages[k]] = languages[k])

const iso639Translations = {
  target: join(__dirname, '../../../client/src/locale/source/iso639_en_US.xml'),
  data: languageKeys
}

saveToXliffFile(playerTranslations, err => {
  if (err) return handleError(err)

  saveToXliffFile(serverTranslations, err => {
    if (err) return handleError(err)

    saveToXliffFile(iso639Translations, err => {
      if (err) return handleError(err)

      process.exit(0)
    })
  })
})

// Then, the server strings

function saveToXliffFile (jsonTranslations: TranslationType, cb: Function) {
  const obj = {
    resources: {
      namespace1: {}
    }
  }
  Object.keys(jsonTranslations.data).forEach(k => obj.resources.namespace1[ k ] = { source: jsonTranslations.data[ k ] })

  jsToXliff12(obj, (err, res) => {
    if (err) return cb(err)

    writeFile(jsonTranslations.target, res, err => {
      if (err) return cb(err)

      return cb(null)
    })
  })
}

function handleError (err: any) {
  console.error(err)
  process.exit(-1)
}