feat: default locale with namespacing
This commit is contained in:
parent
28cf67cdaa
commit
1dfb55e803
@ -145,7 +145,7 @@
|
|||||||
v-list.py-0
|
v-list.py-0
|
||||||
template(v-for='(lc, idx) of locales')
|
template(v-for='(lc, idx) of locales')
|
||||||
v-list-tile(@click='changeLocale(lc)')
|
v-list-tile(@click='changeLocale(lc)')
|
||||||
v-list-tile-action: v-chip(:color='lc.code === $i18n.i18next.language ? `blue` : `grey`', small, label, dark) {{lc.code.toUpperCase()}}
|
v-list-tile-action: v-chip(:color='lc.code === locale ? `blue` : `grey`', small, label, dark) {{lc.code.toUpperCase()}}
|
||||||
v-list-tile-title {{lc.name}}
|
v-list-tile-title {{lc.name}}
|
||||||
v-divider.my-0(v-if='idx < locales.length - 1')
|
v-divider.my-0(v-if='idx < locales.length - 1')
|
||||||
v-tooltip(bottom, v-if='isAuthenticated && isAdmin')
|
v-tooltip(bottom, v-if='isAuthenticated && isAdmin')
|
||||||
@ -231,6 +231,7 @@ export default {
|
|||||||
isLoading: get('isLoading'),
|
isLoading: get('isLoading'),
|
||||||
title: get('site/title'),
|
title: get('site/title'),
|
||||||
path: get('page/path'),
|
path: get('page/path'),
|
||||||
|
locale: get('page/locale'),
|
||||||
mode: get('page/mode'),
|
mode: get('page/mode'),
|
||||||
name: get('user/name'),
|
name: get('user/name'),
|
||||||
email: get('user/email'),
|
email: get('user/email'),
|
||||||
@ -293,19 +294,19 @@ export default {
|
|||||||
this.newPageModal = true
|
this.newPageModal = true
|
||||||
},
|
},
|
||||||
pageNewCreate ({ path, locale }) {
|
pageNewCreate ({ path, locale }) {
|
||||||
window.location.assign(`/e/${path}`)
|
window.location.assign(`/e/${locale}/${path}`)
|
||||||
},
|
},
|
||||||
pageView () {
|
pageView () {
|
||||||
window.location.assign(`/${this.path}`)
|
window.location.assign(`/${this.locale}/${this.path}`)
|
||||||
},
|
},
|
||||||
pageEdit () {
|
pageEdit () {
|
||||||
window.location.assign(`/e/${this.path}`)
|
window.location.assign(`/e/${this.locale}/${this.path}`)
|
||||||
},
|
},
|
||||||
pageHistory () {
|
pageHistory () {
|
||||||
window.location.assign(`/h/${this.path}`)
|
window.location.assign(`/h/${this.locale}/${this.path}`)
|
||||||
},
|
},
|
||||||
pageSource () {
|
pageSource () {
|
||||||
window.location.assign(`/s/${this.path}`)
|
window.location.assign(`/s/${this.locale}/${this.path}`)
|
||||||
},
|
},
|
||||||
pageMove () {
|
pageMove () {
|
||||||
this.$store.commit('showNotification', {
|
this.$store.commit('showNotification', {
|
||||||
|
@ -12,44 +12,44 @@
|
|||||||
:width='2'
|
:width='2'
|
||||||
v-show='searchLoading'
|
v-show='searchLoading'
|
||||||
)
|
)
|
||||||
.d-flex(style='min-height:400px;')
|
//- .d-flex(style='min-height:400px;')
|
||||||
v-flex(xs4).grey(:class='darkMode ? `darken-4` : `lighten-3`')
|
//- v-flex(xs4).grey(:class='darkMode ? `darken-4` : `lighten-3`')
|
||||||
v-toolbar(color='grey darken-3', dark, dense, flat)
|
//- v-toolbar(color='grey darken-3', dark, dense, flat)
|
||||||
.body-2 Folders
|
//- .body-2 Folders
|
||||||
v-spacer
|
//- v-spacer
|
||||||
v-btn(icon): v-icon create_new_folder
|
//- v-btn(icon): v-icon create_new_folder
|
||||||
v-treeview(
|
//- v-treeview(
|
||||||
v-model='tree'
|
//- v-model='tree'
|
||||||
:items='treeFolders'
|
//- :items='treeFolders'
|
||||||
:load-children='fetchFolders'
|
//- :load-children='fetchFolders'
|
||||||
activatable
|
//- activatable
|
||||||
open-on-click
|
//- open-on-click
|
||||||
hoverable
|
//- hoverable
|
||||||
)
|
//- )
|
||||||
template(slot='prepend', slot-scope='{ item, open, leaf }')
|
//- template(slot='prepend', slot-scope='{ item, open, leaf }')
|
||||||
v-icon {{ open ? 'folder_open' : 'folder' }}
|
//- v-icon {{ open ? 'folder_open' : 'folder' }}
|
||||||
v-flex(xs8)
|
//- v-flex(xs8)
|
||||||
v-toolbar(color='grey darken-2', dark, dense, flat)
|
//- v-toolbar(color='grey darken-2', dark, dense, flat)
|
||||||
.body-2 Pages
|
//- .body-2 Pages
|
||||||
v-spacer
|
//- v-spacer
|
||||||
v-btn(icon): v-icon forward
|
//- v-btn(icon): v-icon forward
|
||||||
v-btn(icon): v-icon delete
|
//- v-btn(icon): v-icon delete
|
||||||
v-list(dense)
|
//- v-list(dense)
|
||||||
v-list-tile
|
//- v-list-tile
|
||||||
v-list-tile-avatar: v-icon insert_drive_file
|
//- v-list-tile-avatar: v-icon insert_drive_file
|
||||||
v-list-tile-title File A
|
//- v-list-tile-title File A
|
||||||
v-divider
|
//- v-divider
|
||||||
v-list-tile
|
//- v-list-tile
|
||||||
v-list-tile-avatar: v-icon insert_drive_file
|
//- v-list-tile-avatar: v-icon insert_drive_file
|
||||||
v-list-tile-title File B
|
//- v-list-tile-title File B
|
||||||
v-divider
|
//- v-divider
|
||||||
v-list-tile
|
//- v-list-tile
|
||||||
v-list-tile-avatar: v-icon insert_drive_file
|
//- v-list-tile-avatar: v-icon insert_drive_file
|
||||||
v-list-tile-title File C
|
//- v-list-tile-title File C
|
||||||
v-divider
|
//- v-divider
|
||||||
v-list-tile
|
//- v-list-tile
|
||||||
v-list-tile-avatar: v-icon insert_drive_file
|
//- v-list-tile-avatar: v-icon insert_drive_file
|
||||||
v-list-tile-title File D
|
//- v-list-tile-title File D
|
||||||
v-card-actions.grey.pa-2(:class='darkMode ? `darken-3-d5` : `lighten-1`')
|
v-card-actions.grey.pa-2(:class='darkMode ? `darken-3-d5` : `lighten-1`')
|
||||||
v-select(
|
v-select(
|
||||||
solo
|
solo
|
||||||
@ -80,6 +80,8 @@
|
|||||||
<script>
|
<script>
|
||||||
import { get } from 'vuex-pathify'
|
import { get } from 'vuex-pathify'
|
||||||
|
|
||||||
|
/* global siteLangs, siteConfig */
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
props: {
|
props: {
|
||||||
value: {
|
value: {
|
||||||
@ -110,7 +112,7 @@ export default {
|
|||||||
currentPath: 'new-page',
|
currentPath: 'new-page',
|
||||||
tree: [],
|
tree: [],
|
||||||
treeChildren: [],
|
treeChildren: [],
|
||||||
namespaces: ['en']
|
namespaces: siteLangs.length ? siteLangs.map(ns => ns.code) : [siteConfig.lang]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
@ -185,6 +185,8 @@
|
|||||||
import _ from 'lodash'
|
import _ from 'lodash'
|
||||||
import { sync, get } from 'vuex-pathify'
|
import { sync, get } from 'vuex-pathify'
|
||||||
|
|
||||||
|
/* global siteLangs, siteConfig */
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
props: {
|
props: {
|
||||||
value: {
|
value: {
|
||||||
@ -197,7 +199,7 @@ export default {
|
|||||||
isPublishStartShown: false,
|
isPublishStartShown: false,
|
||||||
isPublishEndShown: false,
|
isPublishEndShown: false,
|
||||||
pageSelectorShown: false,
|
pageSelectorShown: false,
|
||||||
namespaces: ['en'],
|
namespaces: siteLangs.length ? siteLangs.map(ns => ns.code) : [siteConfig.lang],
|
||||||
tourSteps: [
|
tourSteps: [
|
||||||
{
|
{
|
||||||
target: '.dialog-header',
|
target: '.dialog-header',
|
||||||
|
@ -66,7 +66,7 @@
|
|||||||
.caption.grey--text.text--darken-1 {{ updatedAt | moment('calendar') }}
|
.caption.grey--text.text--darken-1 {{ updatedAt | moment('calendar') }}
|
||||||
v-spacer
|
v-spacer
|
||||||
v-tooltip(left)
|
v-tooltip(left)
|
||||||
v-btn.btn-animate-edit(icon, slot='activator', :href='"/e/" + path')
|
v-btn.btn-animate-edit(icon, slot='activator', :href='"/e/" + locale + "/" + path')
|
||||||
v-icon(color='grey') edit
|
v-icon(color='grey') edit
|
||||||
span {{$t('common:page.editPage')}}
|
span {{$t('common:page.editPage')}}
|
||||||
v-divider
|
v-divider
|
||||||
|
@ -18,7 +18,8 @@ defaults:
|
|||||||
storage: ./db.sqlite
|
storage: ./db.sqlite
|
||||||
ssl:
|
ssl:
|
||||||
enabled: false
|
enabled: false
|
||||||
pool: {}
|
pool:
|
||||||
|
min: 0
|
||||||
bindIP: 0.0.0.0
|
bindIP: 0.0.0.0
|
||||||
logLevel: info
|
logLevel: info
|
||||||
uploads:
|
uploads:
|
||||||
|
@ -56,7 +56,7 @@ module.exports = {
|
|||||||
WIKI.config.lang.code = args.locale
|
WIKI.config.lang.code = args.locale
|
||||||
WIKI.config.lang.autoUpdate = args.autoUpdate
|
WIKI.config.lang.autoUpdate = args.autoUpdate
|
||||||
WIKI.config.lang.namespacing = args.namespacing
|
WIKI.config.lang.namespacing = args.namespacing
|
||||||
WIKI.config.lang.namespaces = args.namespaces
|
WIKI.config.lang.namespaces = _.union(args.namespaces, [args.locale])
|
||||||
|
|
||||||
const newLocale = await WIKI.models.locales.query().select('isRTL').where('code', args.locale).first()
|
const newLocale = await WIKI.models.locales.query().select('isRTL').where('code', args.locale).first()
|
||||||
WIKI.config.lang.rtl = newLocale.isRTL
|
WIKI.config.lang.rtl = newLocale.isRTL
|
||||||
|
@ -13,7 +13,7 @@ module.exports = {
|
|||||||
*/
|
*/
|
||||||
parsePath (rawPath, opts = {}) {
|
parsePath (rawPath, opts = {}) {
|
||||||
let pathObj = {
|
let pathObj = {
|
||||||
locale: 'en',
|
locale: WIKI.config.lang.code,
|
||||||
path: 'home',
|
path: 'home',
|
||||||
private: false,
|
private: false,
|
||||||
privateNS: ''
|
privateNS: ''
|
||||||
|
Loading…
Reference in New Issue
Block a user