clear all the tabs (that have data) when the client disconnects

This commit is contained in:
Damien Churchill 2009-02-21 04:04:05 +00:00
parent 4eb70ec484
commit 28bbd0cc62

View File

@ -54,6 +54,12 @@ Deluge.ProgressBar = Ext.extend(Ext.ProgressBar, {
Ext.reg('deluge-progress', Deluge.ProgressBar); Ext.reg('deluge-progress', Deluge.ProgressBar);
Deluge.Details = { Deluge.Details = {
clear: function() {
this.Panel.items.each(function(item) {
if (item.clear) item.clear();
});
},
update: function(tab) { update: function(tab) {
var torrent = Deluge.Torrents.getSelected(); var torrent = Deluge.Torrents.getSelected();
if (!torrent) return; if (!torrent) return;
@ -66,6 +72,7 @@ Deluge.Details = {
onRender: function(panel) { onRender: function(panel) {
Deluge.Torrents.Grid.on('rowclick', this.onTorrentsClick.bindWithEvent(this)); Deluge.Torrents.Grid.on('rowclick', this.onTorrentsClick.bindWithEvent(this));
Deluge.Events.on('disconnect', this.clear.bind(this));
}, },
onTabChange: function(panel, tab) { onTabChange: function(panel, tab) {
@ -92,6 +99,7 @@ Deluge.Details.Status = {
listeners: {'render': Deluge.Details.Status.onStatusRender} listeners: {'render': Deluge.Details.Status.onStatusRender}
}); });
this.panel.update = this.update.bind(this); this.panel.update = this.update.bind(this);
this.panel.clear = this.clear.bind(this);
}, },
onStatusRender: function(panel) { onStatusRender: function(panel) {
@ -142,6 +150,14 @@ Deluge.Details.Status = {
Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Status, { Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Status, {
onSuccess: this.onRequestComplete.bind(this) onSuccess: this.onRequestComplete.bind(this)
}); });
},
clear: function() {
if (!this.fields) return;
this.progressBar.updateProgress(0, ' ');
this.fields.each(function(value, key) {
value.set('text', '');
}, this);
} }
} }
@ -154,6 +170,7 @@ Deluge.Details.Details = {
}); });
this.doUpdate = false; this.doUpdate = false;
this.panel.update = this.update.bind(this); this.panel.update = this.update.bind(this);
this.panel.clear = this.clear.bind(this);
}, },
onLoaded: function() { onLoaded: function() {
@ -192,12 +209,25 @@ Deluge.Details.Details = {
Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Details, { Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Details, {
onSuccess: this.onRequestComplete.bindWithEvent(this, torrentId) onSuccess: this.onRequestComplete.bindWithEvent(this, torrentId)
}); });
},
clear: function() {
if (!this.fields) return;
this.fields.each(function(value, key) {
value.set('text', '');
}, this);
} }
} }
Deluge.Details.Files = { Deluge.Details.Files = {
onRender: function(panel) { onRender: function(panel) {
this.panel = panel; this.panel = panel;
this.panel.clear = this.clear.bind(this);
this.panel.update = this.update.bind(this);
},
clear: function() {
}, },
update: function(torrentId) { update: function(torrentId) {
@ -209,6 +239,7 @@ Deluge.Details.Peers = {
onRender: function(panel) { onRender: function(panel) {
this.panel = panel; this.panel = panel;
this.panel.update = this.update.bind(this); this.panel.update = this.update.bind(this);
this.panel.clear = this.clear.bind(this);
}, },
onRequestComplete: function(torrent) { onRequestComplete: function(torrent) {
@ -219,6 +250,10 @@ Deluge.Details.Peers = {
this.Store.loadData(peers); this.Store.loadData(peers);
}, },
clear: function() {
this.Store.loadData([]);
},
update: function(torrentId) { update: function(torrentId) {
Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Peers, { Deluge.Client.core.get_torrent_status(torrentId, Deluge.Keys.Peers, {
onSuccess: this.onRequestComplete.bindWithEvent(this, torrentId) onSuccess: this.onRequestComplete.bindWithEvent(this, torrentId)