From 7768f7f567f1f277c3937a394d91ecd266fbb0b0 Mon Sep 17 00:00:00 2001 From: Romain Lenzotti Date: Thu, 1 Mar 2018 14:28:14 +0100 Subject: [PATCH] feat(fetch): Add fallback languages configuration. fallbackLanguages give the possibility to configure a list of languages which must used the default language when a page is missing in the requested language. --- docs/configuration.md | 22 ++++++++++++++++++ src/core/fetch/index.js | 49 +++++++++++++++++++++++++++++++---------- 2 files changed, 59 insertions(+), 12 deletions(-) diff --git a/docs/configuration.md b/docs/configuration.md index 828ea61ae..532eccd8d 100644 --- a/docs/configuration.md +++ b/docs/configuration.md @@ -413,3 +413,25 @@ window.$docsify = { ext: '.md' }; ``` + +## fallbackLanguages + +* type: `Array` + +List of languages that will fallback to the default language when a page is request and didn't exists for the given local. + +Example: + + - try to fetch the page of `/de/overview`. If this page exists, it'll be displayed + - then try to fetch the default page `/overview` (depending on the default language). If this page exists, it'll be displayed + - then display 404 page. + + +```js +window.$docsify = { + fallbackLanguages: [ + "fr", + "de" + ] +}; +``` diff --git a/src/core/fetch/index.js b/src/core/fetch/index.js index a7f480321..035f2ef3f 100644 --- a/src/core/fetch/index.js +++ b/src/core/fetch/index.js @@ -22,15 +22,39 @@ export function fetchMixin (proto) { proto._fetch = function (cb = noop) { const { path, query } = this.route const qs = stringifyQuery(query, ['id']) - const { loadNavbar, loadSidebar, requestHeaders } = this.config - + const { loadNavbar, loadSidebar, requestHeaders, fallbackLanguages } = this.config // Abort last request last && last.abort && last.abort() - last = get(this.router.getFile(path) + qs, true, requestHeaders) + const file = this.router.getFile(path) + last = get(file + qs, true, requestHeaders) // Current page is html - this.isHTML = /\.html$/g.test(path) + this.isHTML = /\.html$/g.test(file) + + const getFallBackPage = (file) => { + if (!fallbackLanguages) { + return false + } + + const local = file.split('/')[1] + + if (fallbackLanguages.indexOf(local) === -1) { + return false + } + + file = file.replace(new RegExp(`^/${local}`), '') + + return get(file + qs, true, requestHeaders) + .then( + (text, opt) => { + this._renderMain(text, opt, loadSideAndNav) + }, + _ => { + return this._renderMain(null, {}, loadSideAndNav) + } + ) + } const loadSideAndNav = () => { if (!loadSidebar) return cb() @@ -45,14 +69,15 @@ export function fetchMixin (proto) { } // Load main content - last.then( - (text, opt) => { - this._renderMain(text, opt, loadSideAndNav) - }, - _ => { - this._renderMain(null, {}, loadSideAndNav) - } - ) + last + .then( + (text, opt) => { + this._renderMain(text, opt, loadSideAndNav) + }, + _ => { + return getFallBackPage(file) || this._renderMain(null, {}, loadSideAndNav) + } + ) // Load nav loadNavbar &&