mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-11 12:04:10 +00:00
change the scheduler plugin to use the new plugin architecture
This commit is contained in:
parent
63b02f28d1
commit
da5697490d
@ -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());
|
|
||||||
})();
|
})();
|
@ -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(""))
|
|
Loading…
x
Reference in New Issue
Block a user