deluge/deluge/ui/web/js/deluge-all/LoginWindow.js
Damien Churchill bf4b826809 webui: fix the login window
The login window now functions correctly under ExtJS 4.0.
2011-10-05 01:36:57 +01:00

163 lines
4.9 KiB
JavaScript

/*!
* Deluge.LoginWindow.js
*
* Copyright (c) Damien Churchill 2009-2011 <damoxc@gmail.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, write to:
* The Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301, USA.
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the OpenSSL
* library.
* You must obey the GNU General Public License in all respects for all of
* the code used other than OpenSSL. If you modify file(s) with this
* exception, you may extend this exception to your version of the file(s),
* but you are not obligated to do so. If you do not wish to do so, delete
* this exception statement from your version. If you delete this exception
* statement from all source files in the program, then also delete it here.
*/
Ext.define('Deluge.LoginWindow', {
extend: 'Ext.Window',
firstShow: true,
bodyStyle: 'padding: 10px 5px;',
buttonAlign: 'center',
closable: false,
closeAction: 'hide',
iconCls: 'x-deluge-login-window-icon',
layout: 'fit',
modal: true,
plain: true,
resizable: false,
title: _('Login'),
width: 300,
height: 105,
initComponent: function() {
this.callParent(arguments);
this.on('show', this.onShow, this);
this.addDocked({
xtype: 'toolbar',
dock: 'bottom',
defaultType: 'button',
items: [
'->',
{text: _('Login'), handler: this.onLogin, scope: this}
]
});
this.form = this.add({
xtype: 'form',
baseCls: 'x-plain',
width: 300,
items: [{
xtype: 'textfield',
fieldLabel: _('Password'),
name: 'password',
inputType: 'password',
labelWidth: 60,
width: 275,
listeners: {
specialkey: {
scope: this,
fn: this.onSpecialKey
}
}
}]
});
},
logout: function() {
deluge.events.fire('logout');
deluge.client.auth.delete_session({
success: function(result) {
this.show(true);
},
scope: this
});
},
show: function(skipCheck) {
if (this.firstShow) {
deluge.client.on('error', this.onClientError, this);
this.firstShow = false;
}
if (skipCheck) {
return this.callParent();
}
deluge.client.auth.check_session({
success: function(result) {
if (result) {
deluge.events.fire('login');
} else {
this.show(true);
}
},
failure: function(result) {
this.show(true);
},
scope: this
});
},
onSpecialKey: function(field, e) {
if (e.getKey() == 13) this.onLogin();
},
onLogin: function() {
var f = this.form.getForm(),
p = f.getValues().password;;
deluge.client.auth.login(p, {
success: function(result) {
if (result) {
deluge.events.fire('login');
this.hide();
f.setValues({password: ''});
} else {
Ext.MessageBox.show({
title: _('Login Failed'),
msg: _('You entered an incorrect password'),
buttons: Ext.MessageBox.OK,
modal: false,
fn: function() {
f.findField('password').focus(true, 10);
},
icon: Ext.MessageBox.WARNING,
iconCls: 'x-deluge-icon-warning'
});
}
},
scope: this
});
},
onClientError: function(errorObj, response, requestOptions) {
if (errorObj.error.code == 1) {
deluge.events.fire('logout');
this.show(true);
}
},
onShow: function() {
this.form.getForm().findField('password').focus(true, 10);
}
});