snappymail/dev/View/Popup/Languages.js

82 lines
1.7 KiB
JavaScript
Raw Normal View History

2014-09-05 06:49:03 +08:00
(function () {
2014-08-25 23:49:01 +08:00
'use strict';
2014-08-21 23:08:34 +08:00
var
2014-08-25 23:49:01 +08:00
_ = require('_'),
ko = require('ko'),
2014-08-25 15:10:51 +08:00
2014-09-05 06:49:03 +08:00
Utils = require('Common/Utils'),
Globals = require('Common/Globals'),
2014-08-21 23:08:34 +08:00
kn = require('Knoin/Knoin'),
AbstractView = require('Knoin/AbstractView')
2014-08-21 23:08:34 +08:00
;
/**
* @constructor
* @extends AbstractView
2014-08-21 23:08:34 +08:00
*/
function LanguagesPopupView()
2014-08-21 23:08:34 +08:00
{
AbstractView.call(this, 'Popups', 'PopupsLanguages');
2014-08-21 23:08:34 +08:00
this.Data = Globals.__APP__.data(); // TODO
2014-08-21 23:08:34 +08:00
this.exp = ko.observable(false);
this.languages = ko.computed(function () {
return _.map(this.Data.languages(), function (sLanguage) {
2014-08-21 23:08:34 +08:00
return {
'key': sLanguage,
'selected': ko.observable(false),
'fullName': Utils.convertLangName(sLanguage)
};
});
}, this);
2014-08-21 23:08:34 +08:00
this.Data.mainLanguage.subscribe(function () {
2014-08-21 23:08:34 +08:00
this.resetMainLanguage();
}, this);
kn.constructorEnd(this);
}
kn.extendAsViewModel(['View/Popup/Languages', 'PopupsLanguagesViewModel'], LanguagesPopupView);
_.extend(LanguagesPopupView.prototype, AbstractView.prototype);
2014-08-21 23:08:34 +08:00
LanguagesPopupView.prototype.languageEnName = function (sLanguage)
2014-08-21 23:08:34 +08:00
{
return Utils.convertLangName(sLanguage, true);
};
LanguagesPopupView.prototype.resetMainLanguage = function ()
2014-08-21 23:08:34 +08:00
{
var sCurrent = this.Data.mainLanguage();
2014-08-21 23:08:34 +08:00
_.each(this.languages(), function (oItem) {
oItem['selected'](oItem['key'] === sCurrent);
});
2014-08-21 23:08:34 +08:00
};
LanguagesPopupView.prototype.onShow = function ()
2014-08-21 23:08:34 +08:00
{
this.exp(true);
this.resetMainLanguage();
2014-08-21 23:08:34 +08:00
};
LanguagesPopupView.prototype.onHide = function ()
2014-08-21 23:08:34 +08:00
{
this.exp(false);
};
LanguagesPopupView.prototype.changeLanguage = function (sLang)
2014-08-21 23:08:34 +08:00
{
this.Data.mainLanguage(sLang);
2014-08-21 23:08:34 +08:00
this.cancelCommand();
};
module.exports = LanguagesPopupView;
2014-08-21 23:08:34 +08:00
2014-09-05 06:49:03 +08:00
}());