add the beginnings of the plugins preferences page

This commit is contained in:
Damien Churchill 2009-08-27 19:13:45 +00:00
parent f10bf6961b
commit 7a09ef5356
4 changed files with 222 additions and 10 deletions

View File

@ -46,23 +46,36 @@ input {
/* Torrent Details */
#torrentDetails dl {
#torrentDetails dl, dl.singleline {
float: left;
min-height: 120px;
}
#torrentDetails dl dt {
#torrentDetails dl dt, dl.singleline dt {
float: left;
font-weight: bold;
height: 19px;
}
#torrentDetails dl dd {
#torrentDetails dl dd, dl.singleline dd {
margin-left: 100px;
width: 140px;
height: 19px;
}
dl.singleline dt {
width: 80px;
}
dl.singleline dd {
margin-left: 85px;
width: auto;
}
.x-deluge-plugins {
background: White;
}
/* Torrent Details - Status Tab */
.x-deluge-status-progressbar {
margin: 5px;

View File

@ -806,3 +806,7 @@ body.x-body-masked .x-window-mc, body.x-body-masked .x-window-plain .x-window-mc
.x-slider-vert .x-slider-inner{
background:transparent url(/themes/slate/slider/slider-v-bg.png) repeat-y 0 0;
}
.x-deluge-plugins .x-panel-body {
background: White;
}

View File

@ -1,7 +1,194 @@
/*Deluge.Preferences.addPage(_('Plugins'), {
Ext.namespace('Ext.deluge.preferences');
Ext.deluge.preferences.Plugins = Ext.extend(Ext.Panel, {
constructor: function(config) {
config = Ext.apply({
border: false,
xtype: 'form',
layout: 'form',
items: []
title: _('Plugins'),
layout: 'border',
height: 400,
cls: 'x-deluge-plugins'
}, config);
Ext.deluge.preferences.Plugins.superclass.constructor.call(this, config);
},
pluginTemplate: new Ext.Template(
'<dl class="singleline">' +
'<dt>Author:</dt><dd>{author}</dd>' +
'<dt>Version:</dt><dd>{version}</dd>' +
'<dt>Author Email:</dt><dd>{email}</dd>' +
'<dt>Homepage:</dt><dd>{homepage}</dd>' +
'<dt>Details:</dt><dd>{details}</dd>' +
'</dl>'
),
initComponent: function() {
Ext.deluge.preferences.Plugins.superclass.initComponent.call(this);
this.defaultValues = {
'version': '',
'email': '',
'homepage': '',
'details': ''
};
this.pluginTemplate.compile();
var checkboxRenderer = function(v, p, record){
p.css += ' x-grid3-check-col-td';
return '<div class="x-grid3-check-col'+(v?'-on':'')+'"> </div>';
}
this.grid = this.add({
xtype: 'grid',
region: 'center',
store: new Ext.data.SimpleStore({
fields: [
{name: 'enabled', mapping: 0},
{name: 'plugin', mapping: 1}
]
}),
columns: [{
id: 'enabled',
header: _('Enabled'),
width: 50,
sortable: true,
renderer: checkboxRenderer,
dataIndex: 'enabled'
}, {
id: 'plugin',
header: _('Plugin'),
sortable: true,
dataIndex: 'plugin'
}],
stripeRows: true,
selModel: new Ext.grid.RowSelectionModel({
singleSelect: true,
listeners: {
'rowselect': {
fn: this.onPluginSelect,
scope: this
}
}
}),
autoExpandColumn: 'plugin',
deferredRender: false,
autoScroll: true,
margins: '5 5 5 5',
bbar: new Ext.Toolbar({
items: [{
cls: 'x-btn-text-icon',
iconCls: 'x-deluge-add',
text: _('Install'),
handler: this.onInstallPlugin,
scope: this
}, {
cls: 'x-btn-text-icon',
text: _('Rescan'),
handler: this.onRescanPlugins,
scope: this
}, '->', {
cls: 'x-btn-text-icon',
text: _('Find More'),
handler: this.onFindMorePlugins,
scope: this
}]
})
});
*/
var fieldset = this.add({
xtype: 'fieldset',
border: false,
region: 'south',
title: _('Info'),
autoHeight: true,
labelWidth: 1
});
this.pluginInfo = fieldset.add({
xtype: 'panel',
border: false,
bodyCfg: {
style: 'margin-left: 10px'
}
});
this.on('show', this.onShow, this);
this.grid.on('cellclick', this.onCellClick, this);
Deluge.Preferences.on('show', this.onPreferencesShow, this);
},
disablePlugin: function(plugin) {
Deluge.Client.core.disable_plugin(plugin);
},
enablePlugin: function(plugin) {
Deluge.Client.core.enable_plugin(plugin);
},
setInfo: function(plugin) {
var values = plugin || this.defaultValues;
this.pluginInfo.body.dom.innerHTML = this.pluginTemplate.apply(values);
},
onCellClick: function(grid, rowIndex, colIndex, e) {
if (colIndex != 0) return;
var r = grid.getStore().getAt(rowIndex);
r.set('enabled', !r.get('enabled'));
r.commit();
if (r.get('enabled')) {
this.enablePlugin(r.get('plugin'));
} else {
this.disablePlugin(r.get('plugin'));
}
},
onGotAvailablePlugins: function(plugins) {
this.availablePlugins = plugins;
Deluge.Client.core.get_enabled_plugins({
success: this.onGotEnabledPlugins,
scope: this
});
},
onGotEnabledPlugins: function(plugins) {
this.enabledPlugins = plugins;
},
onGotPluginInfo: function(info) {
var values = {
author: info['Author'],
version: info['Version'],
email: info['Author-email'],
homepage: info['Home-page'],
details: info['Description']
}
this.setInfo(values);
delete info;
},
onPluginSelect: function(selmodel, rowIndex, r) {
Deluge.Client.web.get_plugin_info(r.get('plugin'), {
success: this.onGotPluginInfo,
scope: this
});
},
onPreferencesShow: function() {
Deluge.Client.core.get_available_plugins({
success: this.onGotAvailablePlugins,
scope: this
});
},
onShow: function() {
Ext.deluge.preferences.Plugins.superclass.onShow.call(this);
this.setInfo();
var plugins = [];
Ext.each(this.availablePlugins, function(plugin) {
if (this.enabledPlugins.indexOf(plugin) > -1) {
plugins.push([true, plugin]);
} else {
plugins.push([false, plugin]);
}
}, this);
this.grid.getStore().loadData(plugins);
}
});
Deluge.Preferences.addPage(new Ext.deluge.preferences.Plugins());

View File

@ -710,5 +710,13 @@ class WebApi(JSONComponent):
@export
def get_plugin_info(self, name):
return component.get("PluginManager").get_plugin_info(name)
return component.get("Web.PluginManager").get_plugin_info(name)
@export
def enable_plugin(self, name):
pass
@export
def disable_plugin(self, name):
pass