Commit e999f2c6 authored by JC Brand's avatar JC Brand

Merge branch 'i18n-momentjs' of https://github.com/thierrytiti/converse.js...

Merge branch 'i18n-momentjs' of https://github.com/thierrytiti/converse.js into thierrytiti-i18n-momentjs

Conflicts:
	converse.js

Also refactored the code to adhere to the style guide.
parents 56cd540f f75b3a07
...@@ -240,41 +240,63 @@ ...@@ -240,41 +240,63 @@
var OPENED = 'opened'; var OPENED = 'opened';
var CLOSED = 'closed'; var CLOSED = 'closed';
// Translation machinery // Detect support for the user's locale
// --------------------- // ------------------------------------
this.isAvailableLocale = function (locale) { this.isConverseLocale = function (locale) { return typeof locales[locale] !== "undefined"; };
if (locales[locale]) { this.isMomentLocale = function (locale) { return moment.locale() != moment.locale(locale); };
return locales[locale];
this.isLocaleAvailable = function (locale, available) {
/* Check whether the locale or sub locale (e.g. en-US, en) is supported.
*
* Parameters:
* (Function) available - returns a boolean indicating whether the locale is supported
*/
if (available(locale)) {
return locale;
} else { } else {
var sublocale = locale.split("-")[0]; var sublocale = locale.split("-")[0];
if (sublocale != locale && locales[sublocale]) { if (sublocale != locale && available(sublocale)) {
return locales[sublocale]; return sublocale;
} }
} }
return null;
}; };
this.detectLocale = function () { this.detectLocale = function (library_check) {
var ret, i; /* Determine which locale is supported by the user's system as well
* as by the relevant library (e.g. converse.js or moment.js).
*
* Parameters:
* (Function) library_check - returns a boolean indicating whether the locale is supported
*/
var locale, i;
if (window.navigator.userLanguage) { if (window.navigator.userLanguage) {
return this.isAvailableLocale(window.navigator.userLanguage); locale = this.isLocaleAvailable(window.navigator.userLanguage, library_check);
} else if (window.navigator.languages) { }
for (i=0; i < window.navigator.languages.length && !ret; i++) { if (window.navigator.languages && !locale) {
ret = this.isAvailableLocale(window.navigator.languages[i]); for (i=0; i<window.navigator.languages.length && !locale; i++) {
} locale = this.isLocaleAvailable(window.navigator.languages[i], library_check);
return ret || locales.en; }
} else if (window.navigator.browserLanguage) { }
return this.isAvailableLocale(window.navigator.browserLanguage); if (window.navigator.browserLanguage && !locale) {
} else if (window.navigator.language) { locale = this.isLocaleAvailable(window.navigator.browserLanguage, library_check);
return this.isAvailableLocale(window.navigator.language); }
} else if (window.navigator.systemLanguage) { if (window.navigator.language && !locale) {
return this.isAvailableLocale(window.navigator.systemLanguage); locale = this.isLocaleAvailable(window.navigator.language, library_check);
} else {
return locales.en;
} }
if (window.navigator.systemLanguage && !locale) {
locale = this.isLocaleAvailable(window.navigator.systemLanguage, library_check);
}
return locale || locales.en;
}; };
this.i18n = settings.i18n ? settings.i18n : this.detectLocale();
if (!moment.locale) { //moment.lang is deprecated after 2.8.1, use moment.locale instead
moment.locale = moment.lang;
}
moment.locale(this.detectLocale(this.isMomentLocale));
this.i18n = settings.i18n ? settings.i18n : locales[this.detectLocale(this.isConverseLocale)];
// Translation machinery
// ---------------------
var __ = $.proxy(utils.__, this); var __ = $.proxy(utils.__, this);
var ___ = utils.___; var ___ = utils.___;
......
...@@ -11,7 +11,8 @@ Changelog ...@@ -11,7 +11,8 @@ Changelog
* #401 Updated French translation [thierrytiti] * #401 Updated French translation [thierrytiti]
* #404 CSS fix: position and width of the div #conversejs [thierrytiti] * #404 CSS fix: position and width of the div #conversejs [thierrytiti]
* #407 CSS: Fonts Path: editabable $font-path via sass/variables.scss [thierrytiti] * #407 CSS: Fonts Path: editabable $font-path via sass/variables.scss [thierrytiti]
* #408 MUC: missing toggle call handler and updated documentation about call. [thierrytiti] * #408 MUC: missing toggle call handler and updated documentation about call [thierrytiti]
* #413 Auto-detect user's locale to show date and time in the right format [thierrytiti]
* #415 closeAllChatBoxes is giving ReferenceError when 2 chats are open [nevcos, jcbrand] * #415 closeAllChatBoxes is giving ReferenceError when 2 chats are open [nevcos, jcbrand]
* #416 Add icon for XA status [thierrytiti] * #416 Add icon for XA status [thierrytiti]
* #418 Logging out with `auto_reconnect=true` causes reconnection retries [jcbrand] * #418 Logging out with `auto_reconnect=true` causes reconnection retries [jcbrand]
...@@ -26,6 +27,8 @@ Changelog ...@@ -26,6 +27,8 @@ Changelog
* Refactored the plugin architecture. Add `overrides` convention for * Refactored the plugin architecture. Add `overrides` convention for
automatically overriding converse.js's methods and Backbone views and models. [jcbrand] automatically overriding converse.js's methods and Backbone views and models. [jcbrand]
* Decouple automatic away and XEP-0352 support. [jcbrand] * Decouple automatic away and XEP-0352 support. [jcbrand]
* CSS: Fonts Path: editabable $font-path via sass/variables.scss [thierrytiti]
* Add offline pretty status to enable translation [thierrytiti]
0.9.3 (2015-05-01) 0.9.3 (2015-05-01)
------------------ ------------------
......
...@@ -26,7 +26,7 @@ require.config({ ...@@ -26,7 +26,7 @@ require.config({
"jquery-private": "src/jquery-private", "jquery-private": "src/jquery-private",
"jquery.browser": "components/jquery.browser/dist/jquery.browser", "jquery.browser": "components/jquery.browser/dist/jquery.browser",
"jquery.easing": "components/jquery-easing-original/index", // XXX: Only required for https://conversejs.org website "jquery.easing": "components/jquery-easing-original/index", // XXX: Only required for https://conversejs.org website
"moment": "components/momentjs/moment", "moment": "components/momentjs/min/moment-with-langs",
"strophe-base64": "components/strophejs/src/base64", "strophe-base64": "components/strophejs/src/base64",
"strophe-bosh": "components/strophejs/src/bosh", "strophe-bosh": "components/strophejs/src/bosh",
"strophe-core": "components/strophejs/src/core", "strophe-core": "components/strophejs/src/core",
......
...@@ -40,7 +40,7 @@ ...@@ -40,7 +40,7 @@
<script type="text/javascript" src="components/backbone//backbone.js"></script> <script type="text/javascript" src="components/backbone//backbone.js"></script>
<script type="text/javascript" src="components/backbone.browserStorage/backbone.browserStorage.js"></script> <script type="text/javascript" src="components/backbone.browserStorage/backbone.browserStorage.js"></script>
<script type="text/javascript" src="components/backbone.overview/backbone.overview.js"></script> <script type="text/javascript" src="components/backbone.overview/backbone.overview.js"></script>
<script type="text/javascript" src="components/momentjs/moment.js"></script> <script type="text/javascript" src="components/momentjs/min/moment-with-langs.js"></script>
<script type="text/javascript" src="components/jquery.browser/dist/jquery.browser.js"></script> <script type="text/javascript" src="components/jquery.browser/dist/jquery.browser.js"></script>
<script type="text/javascript" src="components/typeahead.js/index.js"></script> <script type="text/javascript" src="components/typeahead.js/index.js"></script>
<script type="text/javascript" src="components/jed/jed.js"></script> <script type="text/javascript" src="components/jed/jed.js"></script>
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment