85 lines
2.4 KiB
JavaScript
85 lines
2.4 KiB
JavaScript
const _ = require('lodash')
|
|
const { createApolloFetch } = require('apollo-fetch')
|
|
|
|
/* global WIKI */
|
|
|
|
module.exports = async () => {
|
|
WIKI.logger.info('Syncing locales with Graph endpoint...')
|
|
|
|
try {
|
|
const apollo = createApolloFetch({
|
|
uri: WIKI.config.graphEndpoint
|
|
})
|
|
|
|
// -> Fetch locales list
|
|
|
|
const respList = await apollo({
|
|
query: `{
|
|
localization {
|
|
locales {
|
|
availability
|
|
code
|
|
name
|
|
nativeName
|
|
isRTL
|
|
createdAt
|
|
updatedAt
|
|
}
|
|
}
|
|
}`
|
|
})
|
|
const locales = _.sortBy(_.get(respList, 'data.localization.locales', []), 'name').map(lc => ({...lc, isInstalled: (lc.code === 'en')}))
|
|
WIKI.cache.set('locales', locales)
|
|
|
|
// -> Download locale strings
|
|
|
|
if (WIKI.config.lang.autoUpdate) {
|
|
const activeLocales = WIKI.config.lang.namespacing ? WIKI.config.lang.namespaces : [WIKI.config.lang.code]
|
|
for (const currentLocale of activeLocales) {
|
|
const localeInfo = _.find(locales, ['code', currentLocale])
|
|
|
|
const respStrings = await apollo({
|
|
query: `query ($code: String!) {
|
|
localization {
|
|
strings(code: $code) {
|
|
key
|
|
value
|
|
}
|
|
}
|
|
}`,
|
|
variables: {
|
|
code: currentLocale
|
|
}
|
|
})
|
|
const strings = _.get(respStrings, 'data.localization.strings', [])
|
|
let lcObj = {}
|
|
_.forEach(strings, row => {
|
|
if (_.includes(row.key, '::')) { return }
|
|
if (_.isEmpty(row.value)) {
|
|
row.value = row.key
|
|
}
|
|
_.set(lcObj, row.key.replace(':', '.'), row.value)
|
|
})
|
|
|
|
await WIKI.models.locales.query().update({
|
|
code: currentLocale,
|
|
strings: lcObj,
|
|
isRTL: localeInfo.isRTL,
|
|
name: localeInfo.name,
|
|
nativeName: localeInfo.nativeName,
|
|
availability: localeInfo.availability
|
|
}).where('code', currentLocale)
|
|
|
|
WIKI.logger.info(`Pulled latest locale updates for ${localeInfo.name} from Graph endpoint: [ COMPLETED ]`)
|
|
}
|
|
}
|
|
|
|
await WIKI.lang.refreshNamespaces()
|
|
|
|
WIKI.logger.info('Syncing locales with Graph endpoint: [ COMPLETED ]')
|
|
} catch (err) {
|
|
WIKI.logger.error('Syncing locales with Graph endpoint: [ FAILED ]')
|
|
WIKI.logger.error(err.message)
|
|
}
|
|
}
|