github.com/shyftnetwork/go-empyrean@v1.8.3-0.20191127201940-fbfca9338f04/shyft_documentation/source/javascripts/app/_lang.js (about)

     1  //= require ../lib/_jquery
     2  
     3  /*
     4  Copyright 2008-2013 Concur Technologies, Inc.
     5  
     6  Licensed under the Apache License, Version 2.0 (the "License"); you may
     7  not use this file except in compliance with the License. You may obtain
     8  a copy of the License at
     9  
    10    http://www.apache.org/licenses/LICENSE-2.0
    11  
    12  Unless required by applicable law or agreed to in writing, software
    13  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
    14  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
    15  License for the specific language governing permissions and limitations
    16  under the License.
    17  */
    18  ;(function () {
    19    'use strict';
    20  
    21    var languages = [];
    22  
    23    window.setupLanguages = setupLanguages;
    24    window.activateLanguage = activateLanguage;
    25    window.getLanguageFromQueryString = getLanguageFromQueryString;
    26  
    27    function activateLanguage(language) {
    28      if (!language) return;
    29      if (language === "") return;
    30  
    31      $(".lang-selector a").removeClass('active');
    32      $(".lang-selector a[data-language-name='" + language + "']").addClass('active');
    33      for (var i=0; i < languages.length; i++) {
    34        $(".highlight.tab-" + languages[i]).hide();
    35        $(".lang-specific." + languages[i]).hide();
    36      }
    37      $(".highlight.tab-" + language).show();
    38      $(".lang-specific." + language).show();
    39  
    40      window.recacheHeights();
    41  
    42      // scroll to the new location of the position
    43      if ($(window.location.hash).get(0)) {
    44        $(window.location.hash).get(0).scrollIntoView(true);
    45      }
    46    }
    47  
    48    // parseURL and stringifyURL are from https://github.com/sindresorhus/query-string
    49    // MIT licensed
    50    // https://github.com/sindresorhus/query-string/blob/7bee64c16f2da1a326579e96977b9227bf6da9e6/license
    51    function parseURL(str) {
    52      if (typeof str !== 'string') {
    53        return {};
    54      }
    55  
    56      str = str.trim().replace(/^(\?|#|&)/, '');
    57  
    58      if (!str) {
    59        return {};
    60      }
    61  
    62      return str.split('&').reduce(function (ret, param) {
    63        var parts = param.replace(/\+/g, ' ').split('=');
    64        var key = parts[0];
    65        var val = parts[1];
    66  
    67        key = decodeURIComponent(key);
    68        // missing `=` should be `null`:
    69        // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
    70        val = val === undefined ? null : decodeURIComponent(val);
    71  
    72        if (!ret.hasOwnProperty(key)) {
    73          ret[key] = val;
    74        } else if (Array.isArray(ret[key])) {
    75          ret[key].push(val);
    76        } else {
    77          ret[key] = [ret[key], val];
    78        }
    79  
    80        return ret;
    81      }, {});
    82    };
    83  
    84    function stringifyURL(obj) {
    85      return obj ? Object.keys(obj).sort().map(function (key) {
    86        var val = obj[key];
    87  
    88        if (Array.isArray(val)) {
    89          return val.sort().map(function (val2) {
    90            return encodeURIComponent(key) + '=' + encodeURIComponent(val2);
    91          }).join('&');
    92        }
    93  
    94        return encodeURIComponent(key) + '=' + encodeURIComponent(val);
    95      }).join('&') : '';
    96    };
    97  
    98    // gets the language set in the query string
    99    function getLanguageFromQueryString() {
   100      if (location.search.length >= 1) {
   101        var language = parseURL(location.search).language;
   102        if (language) {
   103          return language;
   104        } else if (jQuery.inArray(location.search.substr(1), languages) != -1) {
   105          return location.search.substr(1);
   106        }
   107      }
   108  
   109      return false;
   110    }
   111  
   112    // returns a new query string with the new language in it
   113    function generateNewQueryString(language) {
   114      var url = parseURL(location.search);
   115      if (url.language) {
   116        url.language = language;
   117        return stringifyURL(url);
   118      }
   119      return language;
   120    }
   121  
   122    // if a button is clicked, add the state to the history
   123    function pushURL(language) {
   124      if (!history) { return; }
   125      var hash = window.location.hash;
   126      if (hash) {
   127        hash = hash.replace(/^#+/, '');
   128      }
   129      history.pushState({}, '', '?' + generateNewQueryString(language) + '#' + hash);
   130  
   131      // save language as next default
   132      localStorage.setItem("language", language);
   133    }
   134  
   135    function setupLanguages(l) {
   136      var defaultLanguage = localStorage.getItem("language");
   137  
   138      languages = l;
   139  
   140      var presetLanguage = getLanguageFromQueryString();
   141      if (presetLanguage) {
   142        // the language is in the URL, so use that language!
   143        activateLanguage(presetLanguage);
   144  
   145        localStorage.setItem("language", presetLanguage);
   146      } else if ((defaultLanguage !== null) && (jQuery.inArray(defaultLanguage, languages) != -1)) {
   147        // the language was the last selected one saved in localstorage, so use that language!
   148        activateLanguage(defaultLanguage);
   149      } else {
   150        // no language selected, so use the default
   151        activateLanguage(languages[0]);
   152      }
   153    }
   154  
   155    // if we click on a language tab, activate that language
   156    $(function() {
   157      $(".lang-selector a").on("click", function() {
   158        var language = $(this).data("language-name");
   159        pushURL(language);
   160        activateLanguage(language);
   161        return false;
   162      });
   163    });
   164  })();