change the scheduler plugin to use the new plugin architecture

This commit is contained in:
Damien Churchill 2009-09-14 10:26:59 +00:00
parent 63b02f28d1
commit da5697490d
2 changed files with 107 additions and 103 deletions

View File

@ -1,92 +1,109 @@
(function() { ScheduleSelectPanel = Ext.extend(Ext.form.FieldSet, {
function createEl(parent, type) { constructor: function(config) {
var el = document.createElement(type); config = Ext.apply({
parent.appendChild(el); title: _('Schedule'),
return el; autoHeight: true
}, config);
ScheduleSelectPanel.superclass.constructor.call(this, config);
},
onRender: function(ct, position) {
ScheduleSelectPanel.superclass.onRender.call(this, ct, position);
var dom = this.body.dom;
var table = createEl(dom, 'table');
function createEl(parent, type) {
var el = document.createElement(type);
parent.appendChild(el);
return el;
}
Ext.each(['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], function(day) {
var row = createEl(table, 'tr');
var label = createEl(row, 'th');
label.setAttribute('style', 'font-weight: bold; padding-right: 5px;');
label.innerHTML = day;
for (var hour = 0; hour < 24; hour++) {
var cell = createEl(row, 'td');
cell.setAttribute('style', 'border: 1px solid Green; width: 16px; height: 20px; background: LightGreen;');
}
});
} }
});
var DAYS = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']; SchedulerPreferences = Ext.extend(Ext.Panel, {
constructor: function(config) {
config = Ext.apply({
border: false,
title: _('Scheduler')
}, config);
SchedulerPreferences.superclass.constructor.call(this, config);
},
ScheduleSelectPanel = Ext.extend(Ext.form.FieldSet, { initComponent: function() {
constructor: function(config) { SchedulerPreferences.superclass.initComponent.call(this);
config = Ext.apply({
title: _('Schedule'),
autoHeight: true
}, config);
ScheduleSelectPanel.superclass.constructor.call(this, config);
},
onRender: function(ct, position) { this.form = this.add({
ScheduleSelectPanel.superclass.onRender.call(this, ct, position); xtype: 'form',
layout: 'form',
border: false,
autoHeight: true
});
var dom = this.body.dom; this.schedule = this.form.add(new ScheduleSelectPanel());
var table = createEl(dom, 'table');
Ext.each(DAYS, function(day) { this.slowSettings = this.form.add({
var row = createEl(table, 'tr'); xtype: 'fieldset',
var label = createEl(row, 'th'); title: _('Slow Settings'),
label.setAttribute('style', 'font-weight: bold; padding-right: 5px;'); autoHeight: true,
label.innerHTML = day; defaultType: 'uxspinner'
for (var hour = 0; hour < 24; hour++) { });
var cell = createEl(row, 'td');
cell.setAttribute('style', 'border: 1px solid Green; width: 16px; height: 20px; background: LightGreen;');
}
});
}
});
SchedulerPreferences = Ext.extend(Ext.Panel, { this.downloadLimit = this.slowSettings.add({
constructor: function(config) { fieldLabel: _('Download Limit'),
config = Ext.apply({ name: 'download_limit'
border: false, });
title: _('Scheduler') this.uploadLimit = this.slowSettings.add({
}, config); fieldLabel: _('Upload Limit'),
SchedulerPreferences.superclass.constructor.call(this, config); name: 'upload_limit'
}, });
this.activeTorrents = this.slowSettings.add({
fieldLabel: _('Active Torrents'),
name: 'active_torrents'
});
},
initComponent: function() { onRender: function(ct, position) {
SchedulerPreferences.superclass.initComponent.call(this); SchedulerPreferences.superclass.onRender.call(this, ct, position);
this.form.layout = new Ext.layout.FormLayout();
this.form.layout.setContainer(this);
this.form.doLayout();
},
this.form = this.add({ onShow: function() {
xtype: 'form', SchedulerPreferences.superclass.onShow.call(this);
layout: 'form', }
border: false, });
autoHeight: true
});
this.schedule = this.form.add(new ScheduleSelectPanel()); SchedulerPlugin = Ext.extend(Deluge.Plugin, {
constructor: function(config) {
config = Ext.apply({
name: "Scheduler"
}, config);
SchedulerPlugin.superclass.constructor.call(this, config);
},
this.slowSettings = this.form.add({ onDisable: function() {
xtype: 'fieldset', Deluge.Preferences.removePage(this.prefsPage);
title: _('Slow Settings'), },
autoHeight: true,
defaultType: 'uxspinner'
});
this.downloadLimit = this.slowSettings.add({ onEnable: function() {
fieldLabel: _('Download Limit'), this.prefsPage = new SchedulerPreferences();
name: 'download_limit' Deluge.Preferences.addPage(this.prefsPage);
}); }
this.uploadLimit = this.slowSettings.add({ });
fieldLabel: _('Upload Limit'),
name: 'upload_limit'
});
this.activeTorrents = this.slowSettings.add({
fieldLabel: _('Active Torrents'),
name: 'active_torrents'
});
},
onRender: function(ct, position) { (function() {
SchedulerPreferences.superclass.onRender.call(this, ct, position); var plugin = new SchedulerPlugin();
this.form.layout = new Ext.layout.FormLayout();
this.form.layout.setContainer(this);
this.form.doLayout();
},
onShow: function() {
SchedulerPreferences.superclass.onShow.call(this);
}
});
Deluge.Preferences.addPage(new SchedulerPreferences());
})(); })();

View File

@ -1,7 +1,7 @@
# #
# webui.py # webui.py
# #
# Copyright (C) 2009 Andrew Resch <andrewresch@gmail.com> # Copyright (C) 2009 Damien Churchill <damoxc@gmail.com>
# #
# Basic plugin template created by: # Basic plugin template created by:
# Copyright (C) 2008 Martijn Voncken <mvoncken@gmail.com> # Copyright (C) 2008 Martijn Voncken <mvoncken@gmail.com>
@ -36,8 +36,6 @@
# statement from all source files in the program, then also delete it here. # statement from all source files in the program, then also delete it here.
# #
import pkg_resources
from deluge.log import LOG as log from deluge.log import LOG as log
from deluge.ui.client import client from deluge.ui.client import client
from deluge import component from deluge import component
@ -46,16 +44,5 @@ from deluge.plugins.pluginbase import WebPluginBase
from common import get_resource from common import get_resource
class WebUI(WebPluginBase): class WebUI(WebPluginBase):
def enable(self):
deluge_web = component.get("DelugeWeb").top_level
deluge_web.add_script("/js/scheduler.js")
javascript = component.get("Javascript").directories scripts = [get_resource("scheduler.js")]
javascript.append(get_resource(""))
def disable(self):
deluge_web = component.get("DelugeWeb").top_level
deluge_web.remove_script("/js/scheduler.js")
javascript = component.get("Javascript").directories
javascript.remove(get_resource(""))