fix: UI localization on load + update all namespaced locales

This commit is contained in:
Nick 2019-06-22 12:44:32 -04:00
parent c82b7066bb
commit d0b73c5a9b
6 changed files with 54 additions and 43 deletions

View File

@ -6,7 +6,7 @@
img.animated.fadeInUp(src='/svg/icon-process.svg', alt='Rendering', style='width: 80px;') img.animated.fadeInUp(src='/svg/icon-process.svg', alt='Rendering', style='width: 80px;')
.admin-header-title .admin-header-title
.headline.primary--text.animated.fadeInLeft Rendering .headline.primary--text.animated.fadeInLeft Rendering
.subheading.grey--text.animated.fadeInLeft.wait-p4s Configure how content is rendered .subheading.grey--text.animated.fadeInLeft.wait-p4s Configure how content is rendered #[v-chip(label, color='primary', small).white--text coming soon]
v-spacer v-spacer
v-btn.animated.fadeInDown.wait-p2s(outline, color='grey', @click='refresh', large) v-btn.animated.fadeInDown.wait-p2s(outline, color='grey', @click='refresh', large)
v-icon refresh v-icon refresh

View File

@ -2,7 +2,7 @@
v-card.editor-modal-media.animated.fadeInLeft(flat, tile) v-card.editor-modal-media.animated.fadeInLeft(flat, tile)
v-container.pa-3(grid-list-lg, fluid) v-container.pa-3(grid-list-lg, fluid)
v-layout(row, wrap) v-layout(row, wrap)
v-flex(xs12, xl9) v-flex(xs12, lg9)
v-card.radius-7.animated.fadeInLeft.wait-p1s(:light='!$vuetify.dark', :dark='$vuetify.dark') v-card.radius-7.animated.fadeInLeft.wait-p1s(:light='!$vuetify.dark', :dark='$vuetify.dark')
v-card-text v-card-text
.d-flex .d-flex
@ -125,7 +125,7 @@
v-icon(left) save_alt v-icon(left) save_alt
span {{$t('common:actions.insert')}} span {{$t('common:actions.insert')}}
v-flex(xs12, xl3) v-flex(xs12, lg3)
v-card.radius-7.animated.fadeInRight.wait-p3s(:light='!$vuetify.dark', :dark='$vuetify.dark') v-card.radius-7.animated.fadeInRight.wait-p3s(:light='!$vuetify.dark', :dark='$vuetify.dark')
v-card-text v-card-text
.d-flex .d-flex

View File

@ -74,12 +74,13 @@
multiple multiple
v-model='tags' v-model='tags'
single-line single-line
:hint='$t(`editor:props.tagsHint`)' :hint='`COMING SOON - ` + $t(`editor:props.tagsHint`)'
persistent-hint persistent-hint
disabled
) )
v-divider v-divider
v-card-text.pb-5.grey(:class='darkMode ? `darken-3-d5` : `lighten-4`') v-card-text.pb-5.grey(:class='darkMode ? `darken-3-d5` : `lighten-4`')
v-subheader.pl-0 {{$t('editor:props.publishState')}} v-subheader.pl-0 {{$t('editor:props.publishState')}} #[v-chip.ml-3(label, color='grey', small, outline).white--text coming soon]
v-container.pa-0(fluid, grid-list-lg) v-container.pa-0(fluid, grid-list-lg)
v-layout(row, wrap) v-layout(row, wrap)
v-flex(xs12, md4) v-flex(xs12, md4)
@ -89,6 +90,7 @@
color='primary' color='primary'
:hint='$t(`editor:props.publishToggleHint`)' :hint='$t(`editor:props.publishToggleHint`)'
persistent-hint persistent-hint
disabled
) )
v-flex(xs12, md4) v-flex(xs12, md4)
v-dialog( v-dialog(
@ -99,7 +101,7 @@
:return-value.sync='publishStartDate' :return-value.sync='publishStartDate'
full-width full-width
width='460px' width='460px'
:disabled='!isPublished' :disabled='!isPublished || true'
) )
v-text-field( v-text-field(
slot='activator' slot='activator'
@ -112,7 +114,7 @@
clearable clearable
:hint='$t(`editor:props.publishStartHint`)' :hint='$t(`editor:props.publishStartHint`)'
persistent-hint persistent-hint
:disabled='!isPublished' :disabled='!isPublished || true'
) )
v-date-picker( v-date-picker(
v-model='publishStartDate' v-model='publishStartDate'
@ -142,7 +144,7 @@
:return-value.sync='publishEndDate' :return-value.sync='publishEndDate'
full-width full-width
width='460px' width='460px'
:disabled='!isPublished' :disabled='!isPublished || true'
) )
v-text-field( v-text-field(
slot='activator' slot='activator'
@ -155,7 +157,7 @@
clearable clearable
:hint='$t(`editor:props.publishEndHint`)' :hint='$t(`editor:props.publishEndHint`)'
persistent-hint persistent-hint
:disabled='!isPublished' :disabled='!isPublished || true'
) )
v-date-picker( v-date-picker(
v-model='publishEndDate' v-model='publishEndDate'

View File

@ -141,8 +141,6 @@ import Prism from '@/libs/prism/prism.js'
import { get } from 'vuex-pathify' import { get } from 'vuex-pathify'
import _ from 'lodash' import _ from 'lodash'
/* global siteLangs */
export default { export default {
components: { components: {
StatusIndicator StatusIndicator
@ -261,10 +259,6 @@ export default {
this.$store.commit('page/SET_UPDATED_AT', this.updatedAt) this.$store.commit('page/SET_UPDATED_AT', this.updatedAt)
this.$store.commit('page/SET_MODE', 'view') this.$store.commit('page/SET_MODE', 'view')
if (siteLangs.length > 0) {
this.$i18n.i18next.changeLanguage(this.locale)
}
}, },
mounted () { mounted () {
Prism.highlightAllUnder(this.$refs.container) Prism.highlightAllUnder(this.$refs.container)

View File

@ -34,6 +34,8 @@ router.get('/healthz', (req, res, next) => {
router.get(['/e', '/e/*'], async (req, res, next) => { router.get(['/e', '/e/*'], async (req, res, next) => {
const pageArgs = pageHelper.parsePath(req.path, { stripExt: true }) const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
_.set(res, 'locals.siteConfig.lang', pageArgs.locale)
if (pageHelper.isReservedPath(pageArgs.path)) { if (pageHelper.isReservedPath(pageArgs.path)) {
return next(new Error('Cannot create this page because it starts with a system reserved path.')) return next(new Error('Cannot create this page because it starts with a system reserved path.'))
} }
@ -95,6 +97,8 @@ router.get(['/p', '/p/*'], (req, res, next) => {
router.get(['/h', '/h/*'], async (req, res, next) => { router.get(['/h', '/h/*'], async (req, res, next) => {
const pageArgs = pageHelper.parsePath(req.path, { stripExt: true }) const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
_.set(res, 'locals.siteConfig.lang', pageArgs.locale)
if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) { if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
_.set(res.locals, 'pageMeta.title', 'Unauthorized') _.set(res.locals, 'pageMeta.title', 'Unauthorized')
return res.render('unauthorized', { action: 'history' }) return res.render('unauthorized', { action: 'history' })
@ -121,6 +125,8 @@ router.get(['/h', '/h/*'], async (req, res, next) => {
router.get(['/s', '/s/*'], async (req, res, next) => { router.get(['/s', '/s/*'], async (req, res, next) => {
const pageArgs = pageHelper.parsePath(req.path, { stripExt: true }) const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
_.set(res, 'locals.siteConfig.lang', pageArgs.locale)
if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) { if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
return res.render('unauthorized', { action: 'source' }) return res.render('unauthorized', { action: 'source' })
} }
@ -160,6 +166,9 @@ router.get('/*', async (req, res, next) => {
userId: req.user.id, userId: req.user.id,
isPrivate: false isPrivate: false
}) })
_.set(res, 'locals.siteConfig.lang', pageArgs.locale)
if (page) { if (page) {
_.set(res.locals, 'pageMeta.title', page.title) _.set(res.locals, 'pageMeta.title', page.title)
_.set(res.locals, 'pageMeta.description', page.description) _.set(res.locals, 'pageMeta.description', page.description)

View File

@ -29,39 +29,45 @@ module.exports = async () => {
}) })
const locales = _.sortBy(_.get(respList, 'data.localization.locales', []), 'name').map(lc => ({...lc, isInstalled: (lc.code === 'en')})) const locales = _.sortBy(_.get(respList, 'data.localization.locales', []), 'name').map(lc => ({...lc, isInstalled: (lc.code === 'en')}))
WIKI.cache.set('locales', locales) WIKI.cache.set('locales', locales)
const currentLocale = _.find(locales, ['code', WIKI.config.lang.code])
// -> Download locale strings // -> Download locale strings
if (WIKI.config.lang.autoUpdate) { if (WIKI.config.lang.autoUpdate) {
const respStrings = await apollo({ const activeLocales = WIKI.config.lang.namespacing ? WIKI.config.lang.namespaces : [WIKI.config.lang.code]
query: `query ($code: String!) { for (const currentLocale of activeLocales) {
localization { const localeInfo = _.find(locales, ['code', currentLocale])
strings(code: $code) {
key
value
}
}
}`,
variables: {
code: WIKI.config.lang.code
}
})
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({ const respStrings = await apollo({
code: WIKI.config.lang.code, query: `query ($code: String!) {
strings: lcObj, localization {
isRTL: currentLocale.isRTL, strings(code: $code) {
name: currentLocale.name, key
nativeName: currentLocale.nativeName value
}).where('code', WIKI.config.lang.code) }
}
}`,
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
}).where('code', currentLocale)
WIKI.logger.info(`Pulled latest locale updates for ${localeInfo.name} from Graph endpoint: [ COMPLETED ]`)
}
} }
await WIKI.lang.refreshNamespaces() await WIKI.lang.refreshNamespaces()