diff options
Diffstat (limited to 'public/js')
| -rw-r--r-- | public/js/extra.js | 10 | ||||
| -rw-r--r-- | public/js/locale.js | 56 | 
2 files changed, 39 insertions, 27 deletions
diff --git a/public/js/extra.js b/public/js/extra.js index 6cda6171..a6b01a91 100644 --- a/public/js/extra.js +++ b/public/js/extra.js @@ -27,6 +27,7 @@ require('prismjs/components/prism-makefile')  require('prismjs/components/prism-gherkin')  require('./lib/common/login') +require('./locale')  require('../vendor/md-toc')  var Viz = require('viz.js')  const ui = getUIElements() @@ -35,7 +36,8 @@ const ui = getUIElements()  window.createtime = null  window.lastchangetime = null  window.lastchangeui = { -  status: $('.ui-status-lastchange'), +  statusChanged: $('.ui-status-lastchange.changed'), +  statusCreated: $('.ui-status-lastchange.created'),    time: $('.ui-lastchange'),    user: $('.ui-lastchangeuser'),    nouser: $('.ui-no-lastchangeuser') @@ -47,9 +49,11 @@ export function updateLastChange () {    if (!window.lastchangeui) return    if (window.createtime) {      if (window.createtime && !window.lastchangetime) { -      window.lastchangeui.status.text('created') +      window.lastchangeui.statusChanged.hide() +      window.lastchangeui.statusCreated.show()      } else { -      window.lastchangeui.status.text('changed') +      window.lastchangeui.statusChanged.show() +      window.lastchangeui.statusCreated.hide()      }      const time = window.lastchangetime || window.createtime      window.lastchangeui.time.html(moment(time).fromNow()) diff --git a/public/js/locale.js b/public/js/locale.js index 670370d4..aca35b98 100644 --- a/public/js/locale.js +++ b/public/js/locale.js @@ -1,32 +1,40 @@  /* eslint-env browser, jquery */  /* global Cookies */ -var lang = 'en' -var userLang = navigator.language || navigator.userLanguage -var userLangCode = userLang.split('-')[0] -var locale = $('.ui-locale') -var supportLangs = [] -$('.ui-locale option').each(function () { -  supportLangs.push($(this).val()) -}) -if (Cookies.get('locale')) { -  lang = Cookies.get('locale') -  if (lang === 'zh') { -    lang = 'zh-TW' +const supported = ['en', 'zh-CN', 'zh-TW', 'fr', 'de', 'ja', 'es', 'ca', 'el', 'pt', 'it', 'tr', 'ru', 'nl', 'hr', 'pl', 'uk', 'hi', 'sv', 'eo', 'da', 'ko', 'id', 'sr', 'vi', 'ar', 'cs', 'sk'] + +function detectLang () { +  if (Cookies.get('locale')) { +    let lang = Cookies.get('locale') +    if (lang === 'zh') { +      lang = 'zh-TW' +    } +    return lang +  } +  const userLang = navigator.language || navigator.userLanguage +  const userLangCode = userLang.split('-')[0] +  if (supported.includes(userLangCode)) { +    return userLangCode +  } else if (supported.includes(userLang)) { +    return userLang    } -} else if (supportLangs.indexOf(userLang) !== -1) { -  lang = supportLangs[supportLangs.indexOf(userLang)] -} else if (supportLangs.indexOf(userLangCode) !== -1) { -  lang = supportLangs[supportLangs.indexOf(userLangCode)] +  return 'en'  } -locale.val(lang) -$('select.ui-locale option[value="' + lang + '"]').attr('selected', 'selected') +const lang = detectLang() +const localeSelector = $('.ui-locale') -locale.change(function () { -  Cookies.set('locale', $(this).val(), { -    expires: 365, -    sameSite: 'strict' +// the following condition is needed as the selector is only available in the intro/history page +if (localeSelector.length > 0) { +  localeSelector.val(lang) +  $('select.ui-locale option[value="' + lang + '"]').attr('selected', 'selected') +  localeSelector.change(function () { +    Cookies.set('locale', $(this).val(), { +      expires: 365, +      sameSite: 'strict' +    }) +    window.location.reload()    }) -  window.location.reload() -}) +} + +window.moment.locale(lang)  | 
