2015-01-07 14:54:03 +00:00
|
|
|
var Avatar = require("../../avatar/Avatar");
|
|
|
|
var Settings = require("./Settings");
|
2015-01-23 12:01:44 +00:00
|
|
|
var UIUtil = require("../../util/UIUtil");
|
2015-02-06 15:46:50 +00:00
|
|
|
var languages = require("../../../../service/translation/languages");
|
|
|
|
|
|
|
|
function generateLanguagesSelectBox()
|
|
|
|
{
|
|
|
|
var currentLang = APP.translation.getCurrentLanguage();
|
|
|
|
var html = "<select id=\"languages_selectbox\">";
|
|
|
|
var langArray = languages.getLanguages();
|
|
|
|
for(var i = 0; i < langArray.length; i++)
|
|
|
|
{
|
|
|
|
var lang = langArray[i];
|
|
|
|
html += "<option ";
|
|
|
|
if(lang === currentLang)
|
|
|
|
html += "selected ";
|
|
|
|
html += "value=\"" + lang + "\" data-i18n='languages:" + lang + "'>";
|
|
|
|
html += "</option>";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return html + "</select>";
|
|
|
|
}
|
2015-01-07 14:54:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
var SettingsMenu = {
|
|
|
|
|
2015-02-06 15:46:50 +00:00
|
|
|
init: function () {
|
|
|
|
$("#updateSettings").before(generateLanguagesSelectBox());
|
|
|
|
$('#settingsmenu>input').keyup(function(event){
|
|
|
|
if(event.keyCode === 13) {//enter
|
|
|
|
SettingsMenu.update();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
$("#updateSettings").click(function () {
|
|
|
|
SettingsMenu.update();
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2015-01-07 14:54:03 +00:00
|
|
|
update: function() {
|
2015-01-23 12:01:44 +00:00
|
|
|
var newDisplayName = UIUtil.escapeHtml($('#setDisplayName').get(0).value);
|
|
|
|
var newEmail = UIUtil.escapeHtml($('#setEmail').get(0).value);
|
2015-01-07 14:54:03 +00:00
|
|
|
|
|
|
|
if(newDisplayName) {
|
|
|
|
var displayName = Settings.setDisplayName(newDisplayName);
|
2015-01-28 14:35:22 +00:00
|
|
|
APP.xmpp.addToPresence("displayName", displayName, true);
|
2015-01-07 14:54:03 +00:00
|
|
|
}
|
|
|
|
|
2015-02-06 15:46:50 +00:00
|
|
|
APP.translation.setLanguage($("#languages_selectbox").val());
|
2015-01-07 14:54:03 +00:00
|
|
|
|
2015-01-28 14:35:22 +00:00
|
|
|
APP.xmpp.addToPresence("email", newEmail);
|
2015-01-07 14:54:03 +00:00
|
|
|
var email = Settings.setEmail(newEmail);
|
|
|
|
|
|
|
|
|
2015-02-06 12:54:19 +00:00
|
|
|
Avatar.setUserAvatar(APP.xmpp.myJid(), email);
|
2015-01-07 14:54:03 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
isVisible: function() {
|
|
|
|
return $('#settingsmenu').is(':visible');
|
|
|
|
},
|
|
|
|
|
|
|
|
setDisplayName: function(newDisplayName) {
|
|
|
|
var displayName = Settings.setDisplayName(newDisplayName);
|
|
|
|
$('#setDisplayName').get(0).value = displayName;
|
2015-01-19 09:20:00 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
onDisplayNameChange: function(peerJid, newDisplayName) {
|
|
|
|
if(peerJid === 'localVideoContainer' ||
|
2015-02-06 12:54:19 +00:00
|
|
|
peerJid === APP.xmpp.myJid()) {
|
2015-01-19 09:20:00 +00:00
|
|
|
this.setDisplayName(newDisplayName);
|
|
|
|
}
|
2015-01-07 14:54:03 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = SettingsMenu;
|